/* Auto-generated bundle — edit the source files, not this one. */

/* ══ ss-old-color-polish-2026.css ══ */
/*
  Skill Sakhi Phase 18 - Old UI Color Polish
  Keeps the original Skill Sakhi red / black / cream identity, but softens
  contrast, improves shadows, and makes the public UI feel more premium.
*/
:root{
  --ss18-black:#0D0D0D;
  --ss18-ink:#151515;
  --ss18-charcoal:#202124;
  --ss18-red:#D42B2B;
  --ss18-red-deep:#B91F27;
  --ss18-red-bright:#E53935;
  --ss18-red-soft:#FFF1F1;
  --ss18-cream:#F8F4EF;
  --ss18-cream-2:#F1ECE5;
  --ss18-line:#E8E1DA;
  --ss18-muted:#6F6A66;
  --ss18-gold:#D6A84F;
  --rd:#D42B2B;
  --rd2:#B91F27;
  --pr:#D42B2B;
  --pr-d:#B91F27;
  --pr-l:#E53935;
  --pr-pale:#FFF1F1;
  --pr-glass:rgba(212,43,43,.08);
  --primary:#D42B2B;
  --accent:#D42B2B;
  --red:#D42B2B;
  --red-pale:#FFF1F1;
  --bk:#0D0D0D;
  --bk2:#181818;
  --bk3:#262626;
  --ink:#151515;
  --tx:#151515;
  --gr:#6F6A66;
  --muted:#6F6A66;
  --line:#E8E1DA;
  --cr:#F8F4EF;
  --cr2:#F1ECE5;
}
body{
  background:
    radial-gradient(circle at 8% 0%,rgba(212,43,43,.045),transparent 28%),
    linear-gradient(180deg,#FFFFFF 0%,#FBF8F4 48%,#FFFFFF 100%)!important;
  color:var(--ss18-ink)!important;
}
.ss-nav{
  background:rgba(255,255,255,.88)!important;
  border-bottom:1px solid rgba(13,13,13,.07)!important;
  box-shadow:0 10px 38px rgba(13,13,13,.06)!important;
}
.ss12-trustbar{
  background:linear-gradient(90deg,#0D0D0D,#191919 58%,#6D171A)!important;
  color:#fff!important;
  box-shadow:0 14px 44px rgba(13,13,13,.18)!important;
}
.ss12-page-band{
  background:
    radial-gradient(circle at 10% 20%,rgba(212,43,43,.12),transparent 30%),
    radial-gradient(circle at 90% 10%,rgba(214,168,79,.11),transparent 32%),
    linear-gradient(135deg,#FFFFFF,#FFF8F4 58%,#F8F4EF)!important;
  border:1px solid rgba(212,43,43,.13)!important;
  box-shadow:0 22px 70px rgba(13,13,13,.08)!important;
}
.page-hero,.hero,.ss-hero{
  background:
    radial-gradient(circle at 12% 14%,rgba(212,43,43,.13),transparent 28%),
    radial-gradient(circle at 84% 18%,rgba(214,168,79,.10),transparent 32%),
    linear-gradient(135deg,#141414,#241B1B 56%,#3A1115)!important;
  color:#fff!important;
}
.page-hero h1,.page-hero p,.hero h1,.hero p,.ss-hero h1,.ss-hero p{color:inherit!important}
.btn-rd,.btn-pr,.btn-ss-primary,.btn-primary,.hero-btn.primary,.ss12-band-btn.red,
.ss15-btn.primary,.cd-btn.red,.cmp-actions .primary,.cmp-search button,.cv-form button{
  background:linear-gradient(135deg,var(--ss18-red),var(--ss18-red-deep))!important;
  border-color:transparent!important;
  color:#fff!important;
  box-shadow:0 14px 34px rgba(212,43,43,.22)!important;
}
.btn-rd:hover,.btn-pr:hover,.btn-ss-primary:hover,.btn-primary:hover,.cd-btn.red:hover{
  background:linear-gradient(135deg,var(--ss18-red-bright),var(--ss18-red-deep))!important;
  box-shadow:0 18px 44px rgba(212,43,43,.28)!important;
}
.t-rd,.t-label,.sec-eyebrow,.ss-sec-label,.hp-eyebrow,.sec-bar-left .label,
.course-row h3 a:hover,.faq-nav-link,.pl-role,.cp-price{
  color:var(--ss18-red)!important;
}
/* Mobile nav links must remain dark — not inheriting the global red */
.mob-link{color:var(--ss18-ink)!important}
.mob-link:hover{color:var(--ss18-red)!important}
/* Card headings inside anchor wrappers must stay dark */
.cat-card b,
.home-action-card b,
.blog-card h3,.blog-card h4,
.story-card h3,.story-card h4,
.event-card h3,.event-card h4,
.faq-card h3,.faq-card h4,
.mentor-card h3,.mentor-card h4,
.course-row h3 a{
  color:var(--ss18-ink)!important;
}
.tag-rd,.badge-ss,.cd-badge,.cmp-badge{
  background:rgba(212,43,43,.09)!important;
  color:var(--ss18-red-deep)!important;
  border-color:rgba(212,43,43,.18)!important;
}
.course-card,.course-box,.course-item,.card-course,.mentor-card,.event-card,.blog-card,.story-card,.faq-card,.home-action-card,.cmp-card,.cd-buy,.cd-review,.cd-mentor,.cd-acc{
  border-color:rgba(13,13,13,.08)!important;
  box-shadow:0 18px 54px rgba(13,13,13,.075)!important;
}
.course-card:hover,.course-box:hover,.course-item:hover,.card-course:hover,.mentor-card:hover,
.event-card:hover,.blog-card:hover,.story-card:hover,.faq-card:hover,.home-action-card:hover{
  border-color:rgba(212,43,43,.24)!important;
  box-shadow:0 30px 82px rgba(13,13,13,.13)!important;
}
.course-card::before,.course-box::before,.course-item::before,.card-course::before{
  background:rgba(13,13,13,.9)!important;
  color:#fff!important;
}
.ss15-rail{
  background:linear-gradient(135deg,rgba(13,13,13,.97),rgba(109,23,26,.96))!important;
  box-shadow:0 24px 70px rgba(13,13,13,.34)!important;
}
.ss15-rail-kicker{color:#FFD8D8!important}
.ss15-counselor{
  border-color:rgba(212,43,43,.18)!important;
  box-shadow:0 18px 48px rgba(13,13,13,.15)!important;
}
.ss15-counselor i,.cd-snap i,.cd-feat i,.ben-ico,.eq-ico{
  background:var(--ss18-red-soft)!important;
  color:var(--ss18-red)!important;
}
.ss15-modal-head,.cv{
  background:
    radial-gradient(circle at top right,rgba(214,168,79,.16),transparent 34%),
    linear-gradient(135deg,#0D0D0D,#6D171A)!important;
}
.ss15-field input:focus,.ss15-field textarea:focus,.input-ss:focus,.field input:focus,.field textarea:focus{
  border-color:rgba(212,43,43,.50)!important;
  box-shadow:0 0 0 4px rgba(212,43,43,.08)!important;
}
.empty-state,.ss-empty,.no-data,.coming-soon{
  border-color:rgba(212,43,43,.24)!important;
  background:linear-gradient(135deg,#FFFFFF,#FFF7F4)!important;
}
.phase16-hero-actions a:first-child,.phase16-compare-bar{
  background:linear-gradient(135deg,#0D0D0D,#351316)!important;
}
.phase16-hero-actions a:last-child,.phase16-clear,.phase16-compare-bar button,
.cmp-search label,.cmp-price,.cv-kicker{
  color:var(--ss18-red-deep)!important;
}
.phase16-compare-bar{box-shadow:0 18px 48px rgba(13,13,13,.20)!important}
.phase16-compare-bar button{
  background:#fff!important;
  color:var(--ss18-red-deep)!important;
}
.phase16-compare-check input:checked+span{
  background:var(--ss18-red)!important;
  border-color:var(--ss18-red)!important;
}
.cmp{
  background:linear-gradient(180deg,#FFFFFF,#FBF8F4 46%,#FFFFFF)!important;
  color:var(--ss18-ink)!important;
}
.cmp-search{
  border-color:rgba(212,43,43,.14)!important;
  box-shadow:0 22px 60px rgba(13,13,13,.08)!important;
}
.cmp-search button,.cmp-actions .primary,.cv-form button{
  background:linear-gradient(135deg,var(--ss18-red),var(--ss18-red-deep))!important;
}
.cd{
  --r:#D42B2B!important;
  --r2:#B91F27!important;
  --ink:#151515!important;
  --mut:#6F6A66!important;
  --line:#E8E1DA!important;
  --soft:#FBF8F4!important;
}
.cd-hero{
  background:radial-gradient(620px 460px at 88% 30%,#FFE8E6 0,rgba(255,232,230,0) 62%),linear-gradient(180deg,#FFF8F4,#fff 78%)!important;
}
.cd-price .now,.cd-meta .rt,.cd-less .pv,.cd-review-form h3{color:var(--ss18-red-deep)!important}
.cd-price .off,.cd-less .pv,.cd-review-form,.cd-jump a:hover,.cd-jump a:focus{background:var(--ss18-red-soft)!important}
.cd-pill i,.cd-learn i,.cd-reqs i,.cd-incl i{color:var(--ss18-red)!important}
.cv-card{
  background:rgba(255,255,255,.09)!important;
  border-color:rgba(255,255,255,.18)!important;
}
.cv-form button{background:linear-gradient(135deg,var(--ss18-red),var(--ss18-red-deep))!important}
.ss-footer,.footer-top{background:#0D0D0D!important}
.ft-soc-btn:hover{background:var(--ss18-red)!important;border-color:var(--ss18-red)!important}
.ft-links a:hover::before{background:var(--ss18-red)!important}
.ft-contact-item i{color:#FFB4B4!important}
::selection{background:rgba(212,43,43,.18);color:var(--ss18-ink)}


/* ══ ss-public-layout-readability-fix-2026.css ══ */
/*
  Skill Sakhi Phase 19 - Public UI Spacing + Readability Fix
  Fixes visual crowding after multiple public CSS phases:
  - sections/cards merging without clear gaps
  - text becoming red/low-contrast inside buttons or dark blocks
  - mobile rows feeling cramped
*/
:root{
  --ss19-gap-xs:10px;
  --ss19-gap-sm:16px;
  --ss19-gap:24px;
  --ss19-gap-lg:36px;
  --ss19-section:76px;
  --ss19-section-sm:46px;
  --ss19-text:#151515;
  --ss19-muted:#6F6A66;
  --ss19-line:rgba(13,13,13,.10);
  --ss19-soft:#FBF8F4;
  --ss19-red:#D42B2B;
  --ss19-red-deep:#B91F27;
}

/* 1) Global readable text reset */
main,
.sec,
.hp-section,
.page-section,
.public-card,
.card,
.course-row,
.course-info,
.course-side,
.cmp,
.cd,
.ss-wrap,
.wrap{
  color:var(--ss19-text);
}
p,
.section-sub,
.ph-sub,
.hp-sub,
.cdx-sub,
.course-info p,
.cmp-body p,
.cd-prose,
.cd-review p,
.ft-about{
  color:var(--ss19-muted);
  line-height:1.72;
}
h1,h2,h3,h4,h5,h6,
.cl-title,
.cd-h1,
.cmp-title,
.sec-title,
.section-title,
.hp-title{
  color:var(--ss19-text);
}

/* 2) Do not let global red link styling ruin buttons/dark panels */
.btn-ss,
.btn-rd,
.btn-pr,
.btn-primary,
.btn-ss-primary,
.ss15-btn,
.cd-btn,
.cmp-actions a,
.hero-btn,
.ss12-band-btn,
.phase16-hero-actions a,
.phase16-compare-bar button,
.cv-form button,
.cmp-search button,
.ft-soc-btn,
.public-edit-toolbar a{
  text-decoration:none!important;
}
.btn-rd,
.btn-pr,
.btn-primary,
.btn-ss-primary,
.ss15-btn.primary,
.cd-btn.red,
.cmp-actions .primary,
.hero-btn.primary,
.ss12-band-btn.red,
.cmp-search button,
.cv-form button{
  color:#fff!important;
}
.btn-out,
.btn-outline,
.ss15-btn.ghost,
.cd-btn:not(.red),
.cmp-actions .ghost{
  color:var(--ss19-text)!important;
  background:#fff!important;
  border-color:var(--ss19-line)!important;
}
.ss-footer a,
.ss-footer p,
.ss-footer span,
.ss-footer li,
.ss15-rail,
.ss15-rail *,
.ss15-modal-head,
.ss15-modal-head *,
.cv,
.cv *,
.page-hero,
.page-hero *,
.hero,
.hero *,
.ss-hero,
.ss-hero *{
  color:inherit;
}
.ss-footer a{color:rgba(255,255,255,.58)!important}
.ss-footer a:hover{color:#fff!important}
.ss15-rail .ss15-btn.primary{color:#7F1D1D!important;background:#fff!important}
.ss15-rail .ss15-btn.ghost{color:#fff!important;background:rgba(255,255,255,.12)!important}
.cv-form button,
.cmp-search button{color:#fff!important}

/* 2b) Hero sections: reset the negative margin-top that was designed for a
   nav-only layout but now overlaps the ss12-page-band shown on inner pages */
.cl-hero,
.cd-hero{
  margin-top:0!important;
  padding-top:40px!important;
}

/* 3) Section separation: prevent blocks from visually merging */
.sec,
.hp-section,
.page-section,
.cl,
.cmp,
.cd,
.cv,
.nf{
  position:relative;
}
.sec,
.hp-section,
.page-section{
  padding-top:var(--ss19-section)!important;
  padding-bottom:var(--ss19-section)!important;
}
.sec + .sec,
.hp-section + .hp-section,
.page-section + .page-section{
  border-top:1px solid rgba(13,13,13,.055);
}
.ss12-page-band{
  margin:18px auto 34px!important;
  width:min(1240px,calc(100% - 36px))!important;
  border-radius:28px!important;
  padding:24px!important;
}
.ss12-trustbar{
  margin-bottom:0!important;
}
.ss12-prefooter{
  margin-top:52px!important;
  margin-bottom:0!important;
  border-radius:32px 32px 0 0!important;
}

/* 4) Standardize public grids/gaps */
.course-grid,
.courses-grid,
.cat-grid,
.cat-grid-full,
.inst-grid,
.mentor-grid,
.mentor-grid-pro,
.blog-grid,
.story-grid,
.gallery-grid,
.pricing-grid,
.faq-grid,
.why-grid,
.feature-strip,
.stat-strip,
.info-grid,
.ss-grid,
.cmp-grid,
.cmp-pick-grid,
.cd-features,
.cd-rel,
.cd-snapshot{
  gap:var(--ss19-gap)!important;
}
.cl-layout{
  gap:30px!important;
  align-items:start!important;
}
.topbar{
  gap:var(--ss19-gap-sm)!important;
  margin-bottom:var(--ss19-gap-sm)!important;
}
.course-list{
  display:grid!important;
  gap:18px!important;
}
.course-row{
  background:#fff!important;
  border:1px solid var(--ss19-line)!important;
  border-radius:24px!important;
  padding:16px!important;
  overflow:hidden!important;
  gap:18px!important;
}
.course-row + .course-row{
  margin-top:0!important;
}
.course-info{
  min-width:0;
}
.course-info h3{
  margin:0 0 8px!important;
  line-height:1.28!important;
}
.course-info p{
  margin:0 0 12px!important;
}
.course-tags{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
}
.course-tags span,
.cd-pill,
.tag-rd,
.badge-ss{
  line-height:1.2!important;
  white-space:normal!important;
}
.course-side{
  gap:12px!important;
}
.mini-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
}
.mini-actions form{
  margin:0!important;
}

/* 5) Cards need internal breathing room */
.card,
.public-card,
.hp-card,
.course-card,
.course-box,
.course-item,
.card-course,
.mentor-card,
.event-card,
.blog-card,
.story-card,
.faq-card,
.home-action-card,
.cmp-card,
.cmp-search,
.cmp-pick-card,
.cd-buy,
.cd-review,
.cd-mentor,
.cd-acc,
.filters{
  background:#fff!important;
  border:1px solid var(--ss19-line)!important;
  border-radius:24px!important;
}
.card-body,
.public-card,
.hp-card,
.mentor-card,
.event-card,
.blog-card,
.story-card,
.faq-card{
  padding:22px!important;
}
.filters{
  padding:22px!important;
  position:sticky;
  top:100px;
}
.filter-title{
  margin:22px 0 10px!important;
  color:var(--ss19-text)!important;
}
.filter-title:first-of-type{
  margin-top:10px!important;
}

/* 6) Compare/certificate pages spacing */
.cmp-wrap,
.cv-wrap,
.cd-wrap,
.cl-wrap{
  padding-left:24px!important;
  padding-right:24px!important;
}
.cmp-wrap{
  padding-top:56px!important;
  padding-bottom:84px!important;
}
.cmp-hero{
  margin-bottom:34px!important;
}
.cmp-card .cmp-body{
  padding:22px!important;
}
.cmp-table{
  gap:0!important;
  border-top:1px solid var(--ss19-line);
  margin-top:16px!important;
}
.cmp-row{
  padding:12px 0!important;
}
.cv-card{
  padding:40px!important;
}
.cv-proof{
  gap:14px!important;
}
.cd-top{
  gap:42px!important;
}
.cd-sec{
  padding:38px 0!important;
}
.cd-buy-in{
  padding:24px!important;
}
.cd-features{
  margin-top:22px!important;
}
.cd-review{
  margin-bottom:16px!important;
}

/* 7) Prevent dark/gradient panels from inheriting wrong text colors */
.ss12-trustbar,
.ss12-trustbar *,
.ss15-modal-head,
.ss15-modal-head *,
.ss15-rail,
.ss15-rail *,
.phase16-compare-bar,
.phase16-compare-bar *,
.cv,
.cv *,
.page-hero,
.page-hero *,
.hero,
.hero *,
.ss-hero,
.ss-hero *,
.ss-footer,
.ss-footer *{
  text-shadow:none;
}
.ss12-trustbar *,
.ss15-modal-head *,
.ss15-rail *,
.phase16-compare-bar *,
.cv *,
.page-hero *,
.hero *,
.ss-hero *{
  color:inherit!important;
}
.phase16-compare-bar button,
.ss15-rail .ss15-btn.primary{
  color:var(--ss19-red-deep)!important;
}

/* 8) Mobile: avoid touching/merged blocks */
/* Single source of truth for body bottom padding that reserves space for
   the sticky ss15-rail (≈90 px tall) + ss15-counselor button (≈50 px) */
@media(max-width:768px){
  body{padding-bottom:120px}
  /* Push WA float above the sticky ss15-rail */
  .ss12-floating-whatsapp,.wa-float{bottom:136px!important}
}
@media(max-width:900px){
  .sec,
  .hp-section,
  .page-section{
    padding-top:var(--ss19-section-sm)!important;
    padding-bottom:var(--ss19-section-sm)!important;
  }
  .cl-layout,
  .cmp-hero,
  .cd-top{
    gap:22px!important;
  }
  .filters{
    position:static!important;
  }
  .course-row{
    padding:14px!important;
    border-radius:20px!important;
  }
  .course-thumb{
    min-height:150px!important;
  }
}
@media(max-width:640px){
  .ss-wrap,
  .wrap,
  .hp-wrap,
  .cdx-wrap,
  .mx-wrap,
  .cl-wrap,
  .cmp-wrap,
  .cv-wrap,
  .cd-wrap{
    padding-left:16px!important;
    padding-right:16px!important;
  }
  .ss12-page-band{
    width:calc(100% - 24px)!important;
    padding:18px!important;
    margin:12px auto 24px!important;
  }
  .card-body,
  .public-card,
  .hp-card,
  .mentor-card,
  .event-card,
  .blog-card,
  .story-card,
  .faq-card,
  .cv-card{
    padding:18px!important;
  }
  .course-list{
    gap:14px!important;
  }
  .mini-actions > *,
  .mini-actions a,
  .mini-actions button{
    flex:1 1 130px!important;
    justify-content:center!important;
  }
  .ss15-rail{
    bottom:12px!important;
  }
}


/* ══ ss-phase21-2026.css ══ */
/*
  Skill Sakhi Phase 21 — LMS Feature Completion
  Covers: mobile filter drawer, empty states, course badge system,
  image fallback placeholder, topbar filter toggle.
*/

/* ─── 1. Mobile filter drawer ─────────────────────────── */

/* Backdrop overlay (mobile only) */
.p21-filter-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 610;
  background: rgba(15,17,22,.52);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}
.p21-filter-backdrop.open { display: block; }

/* Toggle button — hidden on desktop */
.p21-filter-toggle {
  display: none;
  align-items: center;
  gap: 8px;
  height: 46px;
  padding: 0 16px;
  border: 1.5px solid var(--ss-line, #e9edf3);
  border-radius: 12px;
  background: #fff;
  color: var(--ss-text, #111827);
  font-weight: 800;
  font-size: 14px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: border-color .16s, background .16s;
}
.p21-filter-toggle:hover {
  border-color: var(--ss-red, #e30613);
  background: #fff5f5;
}
.p21-filter-toggle i { font-size: 18px; }
.p21-active-cnt {
  min-width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--ss-red, #e30613);
  color: #fff; font-size: 11px; font-weight: 900;
  display: grid; place-items: center;
  line-height: 1;
}

/* Filter panel — drawer on mobile, sidebar on desktop */
@media(max-width:900px){
  .p21-filter-toggle { display: inline-flex; }

  .filters {
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    width: min(300px, 86vw) !important;
    top: 0 !important;
    border-radius: 0 22px 22px 0 !important;
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 630;
    transform: translateX(-110%);
    transition: transform .28s cubic-bezier(.22,.61,.36,1), box-shadow .28s;
    max-height: 100dvh;
    padding-top: 0 !important;
    box-shadow: none;
  }
  .filters.p21-open {
    transform: translateX(0);
    box-shadow: 8px 0 48px rgba(0,0,0,.24) !important;
  }

  /* Hide the old h3 inside filters on mobile (replaced by p21-filter-head) */
  .filters > h3:first-child { display: none; }

  /* Filter drawer header */
  .p21-filter-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 22px 16px;
    border-bottom: 1px solid rgba(13,13,13,.08);
    margin-bottom: 4px;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 2;
  }
  .p21-filter-head h3 {
    font-size: 16px; font-weight: 800; margin: 0;
    color: #15171C;
  }
  .p21-filter-close {
    width: 36px; height: 36px;
    border: 1.5px solid rgba(13,13,13,.12);
    border-radius: 50%;
    background: #fff;
    display: grid; place-items: center;
    font-size: 20px; cursor: pointer;
    color: #374151;
    flex-shrink: 0;
  }
  .p21-filter-close:hover { background: #fee2e2; border-color: #e11d2a; color: #e11d2a; }

  /* Apply button row at bottom of drawer */
  .p21-filter-apply-row {
    padding: 16px 22px 24px;
    border-top: 1px solid rgba(13,13,13,.08);
    margin-top: 8px;
    display: flex;
    gap: 10px;
  }
  .p21-apply-btn {
    flex: 1;
    height: 46px;
    border: 0;
    border-radius: 12px;
    background: var(--ss-red, #e30613);
    color: #fff;
    font-weight: 800;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none;
  }
  .p21-clear-btn {
    height: 46px;
    padding: 0 18px;
    border: 1.5px solid rgba(13,13,13,.12);
    border-radius: 12px;
    background: #fff;
    color: #374151;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

@media(min-width:901px){
  /* On desktop the filter head is hidden — the existing h3 inside .filters handles the title */
  .p21-filter-head { display: none; }
  .p21-filter-apply-row { display: none; }
}

/* ─── 2. Empty state ──────────────────────────────────── */
.p21-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 64px 32px;
  border: 1.5px dashed rgba(225,29,42,.18);
  border-radius: 24px;
  background: linear-gradient(135deg, #fff 0%, #fff8f8 100%);
}
.p21-empty-icon {
  width: 80px; height: 80px;
  border-radius: 22px;
  background: #FEE2E2;
  display: grid; place-items: center;
  font-size: 36px;
  color: #E11D2A;
  margin-bottom: 20px;
}
.p21-empty h3 {
  font-size: 20px; font-weight: 800;
  color: #15171C;
  font-family: 'Poppins', sans-serif;
  letter-spacing: -.03em;
  margin: 0 0 8px;
}
.p21-empty p {
  color: #6B7280; font-size: 14.5px;
  max-width: 380px; margin: 0 0 24px;
  line-height: 1.68;
}
.p21-empty-actions {
  display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
}
.p21-empty-actions a {
  display: inline-flex; align-items: center; gap: 8px;
  height: 46px; padding: 0 22px;
  border-radius: 12px; font-weight: 800; font-size: 14px;
  text-decoration: none;
  transition: transform .16s, box-shadow .16s;
}
.p21-ea-primary {
  background: var(--ss-red, #e30613);
  color: #fff !important;
  box-shadow: 0 8px 24px rgba(225,29,42,.22);
}
.p21-ea-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(225,29,42,.30) !important; }
.p21-ea-ghost {
  border: 1.5px solid rgba(13,13,13,.14);
  color: #374151 !important;
  background: #fff;
}
.p21-ea-ghost:hover { border-color: #aeb2ba; background: #fafafa; }

/* ─── 3. Course card badge system ────────────────────── */
.p21-cbadge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10.5px; font-weight: 800; letter-spacing: .08em;
  text-transform: uppercase; padding: 4px 10px;
  border-radius: 20px; line-height: 1;
  white-space: nowrap;
}
.p21-cbadge i { font-size: 11px; }
.p21-badge-bestseller { background: #FEF3C7; color: #92400E; }
.p21-badge-new        { background: #D1FAE5; color: #065F46; }
.p21-badge-popular    { background: #EDE9FE; color: #5B21B6; }
.p21-badge-women      { background: #FCE7F3; color: #9D174D; }
.p21-badge-featured   { background: #DBEAFE; color: #1E40AF; }

/* ─── 4. Image fallback placeholder ──────────────────── */
img[data-p21-fb] {
  transition: opacity .2s;
}
.p21-img-wrap {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #f1f5f9, #e9ecf0);
}
.p21-img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #f1f5f9 25%, #e2e8f0 50%, #f1f5f9 75%);
  background-size: 200% 200%;
  animation: p21-shimmer 1.6s infinite;
  opacity: 0;
  pointer-events: none;
  z-index: 1;
}
.p21-img-wrap.p21-loading::after { opacity: 1; }
@keyframes p21-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

/* ─── 5. Topbar search / sort / filter row ───────────── */
@media(max-width:900px){
  .topbar {
    display: grid !important;
    grid-template-columns: 1fr auto auto !important;
    gap: 10px !important;
    align-items: center !important;
  }
  .topbar .search-big { grid-column: 1 / -1; }
  .topbar .sort { max-width: 140px; }
}
@media(max-width:480px){
  .topbar {
    grid-template-columns: 1fr auto !important;
  }
  .p21-filter-toggle { font-size: 0; padding: 0 13px; }
  .p21-filter-toggle i { font-size: 20px; }
  .p21-filter-toggle .p21-active-cnt { font-size: 10px; }
}


/* ══ ss-phase22-2026.css ══ */
/*
  Skill Sakhi Phase 22 — Conversion & Sales Package
  Covers: coupon banner, lead/exit popups, preview modal,
  trust badges, recently viewed widget, WA tracking UI.
*/

/* ──────────────────────────────────────────────────────
   1. COUPON COUNTDOWN BANNER
   ────────────────────────────────────────────────────── */
.ss22-banner{
  position:relative;
  z-index:800;
  background:linear-gradient(90deg,#15171C 0%,#1d1f27 48%,#261419 100%);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:11px 60px 11px 24px;
  flex-wrap:wrap;
  min-height:46px;
}
.ss22-banner[hidden]{display:none}
.ss22-banner-text{
  font-size:13.5px;font-weight:700;
  display:flex;align-items:center;gap:9px;flex-wrap:wrap;
  justify-content:center;
}
.ss22-banner-text .em{color:#fecaca}
.ss22-banner-cta{
  display:inline-flex;align-items:center;gap:6px;
  background:#E11D2A;color:#fff;
  font-size:12.5px;font-weight:800;
  padding:6px 14px;border-radius:8px;
  text-decoration:none;white-space:nowrap;
  transition:background .16s;
}
.ss22-banner-cta:hover{background:#C2121E;color:#fff}
.ss22-timer{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);
  border-radius:8px;padding:4px 10px;font-size:12px;font-weight:800;
  font-variant-numeric:tabular-nums;letter-spacing:.02em;
}
.ss22-timer-seg{display:flex;flex-direction:column;align-items:center}
.ss22-timer-num{font-size:15px;font-weight:900;line-height:1;color:#fff}
.ss22-timer-lbl{font-size:8.5px;color:rgba(255,255,255,.5);letter-spacing:.06em;text-transform:uppercase;margin-top:1px}
.ss22-timer-sep{font-size:16px;font-weight:900;color:rgba(255,255,255,.4);align-self:flex-start;margin-top:1px}
.ss22-banner-dismiss{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;
  border:0;border-radius:50%;
  background:rgba(255,255,255,.10);color:rgba(255,255,255,.7);
  display:grid;place-items:center;font-size:16px;cursor:pointer;
  transition:background .14s;
}
.ss22-banner-dismiss:hover{background:rgba(255,255,255,.22);color:#fff}
@media(max-width:600px){
  .ss22-banner{gap:10px;padding:10px 44px 10px 14px;font-size:12.5px}
  .ss22-timer{display:none}
}

/* ──────────────────────────────────────────────────────
   2. EXIT INTENT POPUP
   ────────────────────────────────────────────────────── */
.ss22-exit-modal{
  position:fixed;inset:0;z-index:1600;
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
.ss22-exit-modal.open{display:flex}
.ss22-exit-bg{
  position:absolute;inset:0;
  background:rgba(10,12,18,.72);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.ss22-exit-card{
  position:relative;
  width:min(520px,100%);
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.45);
}
.ss22-exit-head{
  background:linear-gradient(140deg,#15171C 0%,#1d1f27 55%,#261419 100%);
  padding:32px 32px 26px;
  text-align:center;position:relative;overflow:hidden;
}
.ss22-exit-head::before{
  content:'';position:absolute;top:-60px;right:-60px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(225,29,42,.22),transparent 68%);
  pointer-events:none;
}
.ss22-exit-emoji{font-size:42px;display:block;margin-bottom:14px;position:relative}
.ss22-exit-title{
  font-family:'Poppins',sans-serif;font-size:22px;font-weight:800;
  color:#fff;letter-spacing:-.03em;margin:0 0 8px;position:relative;
}
.ss22-exit-sub{font-size:14px;color:rgba(255,255,255,.68);margin:0;position:relative;line-height:1.6}
.ss22-exit-body{background:#fff;padding:26px 32px 28px}
.ss22-exit-field{margin-bottom:14px}
.ss22-exit-field label{
  display:block;font-size:11.5px;font-weight:800;
  color:#6B7280;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px;
}
.ss22-exit-field input{
  width:100%;border:1.5px solid #E8E8EC;border-radius:12px;
  padding:12px 14px;font-size:14px;font-family:inherit;
  outline:none;background:#fff;
  transition:border-color .16s,box-shadow .16s;
}
.ss22-exit-field input:focus{border-color:#E11D2A;box-shadow:0 0 0 4px rgba(225,29,42,.08)}
.ss22-exit-submit{
  width:100%;height:50px;border:0;border-radius:12px;
  background:#E11D2A;color:#fff;font-weight:800;font-size:15px;
  font-family:inherit;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:9px;
  transition:background .16s,transform .16s;
  box-shadow:0 8px 24px rgba(225,29,42,.24);
}
.ss22-exit-submit:hover{background:#C2121E;transform:translateY(-1px)}
.ss22-exit-skip{
  display:block;text-align:center;margin-top:14px;
  font-size:13px;color:#9CA3AF;cursor:pointer;
  text-decoration:underline;text-underline-offset:3px;
}
.ss22-exit-skip:hover{color:#6B7280}
.ss22-exit-close{
  position:absolute;right:14px;top:14px;z-index:2;
  width:36px;height:36px;border:0;border-radius:50%;
  background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);
  display:grid;place-items:center;cursor:pointer;font-size:20px;
  transition:background .14s;
}
.ss22-exit-close:hover{background:rgba(255,255,255,.24)}

/* ──────────────────────────────────────────────────────
   3. COURSE PREVIEW MODAL (listing page)
   ────────────────────────────────────────────────────── */
.ss22-preview-modal{
  position:fixed;inset:0;z-index:1500;
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
.ss22-preview-modal.open{display:flex}
.ss22-preview-bg{
  position:absolute;inset:0;
  background:rgba(8,10,18,.88);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.ss22-preview-box{
  position:relative;
  width:min(940px,100%);
  background:#06070a;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 40px 120px rgba(0,0,0,.6);
}
.ss22-preview-close{
  position:absolute;right:12px;top:12px;z-index:4;
  width:40px;height:40px;border:0;border-radius:50%;
  background:rgba(255,255,255,.94);color:#15171C;
  display:grid;place-items:center;cursor:pointer;font-size:22px;
  box-shadow:0 4px 16px rgba(0,0,0,.24);
  transition:background .14s;
}
.ss22-preview-close:hover{background:#fff}
.ss22-preview-frame{aspect-ratio:16/9;background:#000;position:relative}
.ss22-preview-frame iframe,
.ss22-preview-frame video{
  position:absolute;inset:0;width:100%;height:100%;
  border:0;display:block;background:#000;
}
.ss22-preview-footer{
  padding:16px 22px;background:#111827;
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;flex-wrap:wrap;
}
.ss22-preview-title{
  font-size:14.5px;font-weight:700;color:#fff;
  font-family:'Poppins',sans-serif;letter-spacing:-.02em;
}
.ss22-preview-cta{
  display:inline-flex;align-items:center;gap:7px;
  background:#E11D2A;color:#fff;
  font-size:13px;font-weight:800;
  padding:9px 18px;border-radius:10px;
  text-decoration:none;white-space:nowrap;
  transition:background .16s;flex-shrink:0;
}
.ss22-preview-cta:hover{background:#C2121E;color:#fff}

/* Preview trigger button on course cards */
.ss22-preview-btn{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:700;
  color:#E11D2A;background:#FDECED;
  border:1.5px solid rgba(225,29,42,.18);
  border-radius:8px;padding:5px 12px;
  cursor:pointer;white-space:nowrap;
  transition:background .14s,border-color .14s;
}
.ss22-preview-btn:hover{background:#FECACA;border-color:rgba(225,29,42,.36)}
.ss22-preview-btn i{font-size:14px}

/* ──────────────────────────────────────────────────────
   4. TRUST BADGE STRIP
   ────────────────────────────────────────────────────── */
.ss22-trust-strip{
  display:flex;align-items:stretch;justify-content:center;
  flex-wrap:wrap;gap:0;
  border:1px solid #E8E8EC;border-radius:16px;
  overflow:hidden;background:#fff;
  margin:18px 0 0;
}
.ss22-trust-item{
  display:flex;align-items:center;gap:10px;
  padding:13px 16px;flex:1;min-width:140px;
  border-right:1px solid #E8E8EC;font-size:12.5px;
  font-weight:700;color:#374151;
}
.ss22-trust-item:last-child{border-right:0}
.ss22-trust-item i{
  font-size:20px;flex-shrink:0;
  color:#E11D2A;
}
.ss22-trust-item span{line-height:1.3}
.ss22-trust-item b{display:block;font-size:13px;font-weight:800;color:#15171C}
.ss22-trust-item small{display:block;font-size:11px;color:#9CA3AF;font-weight:500}
@media(max-width:600px){
  .ss22-trust-strip{flex-direction:column}
  .ss22-trust-item{border-right:0;border-bottom:1px solid #E8E8EC}
  .ss22-trust-item:last-child{border-bottom:0}
}

/* Compact trust row (payment page) */
.ss22-trust-row{
  display:flex;align-items:center;justify-content:center;
  gap:20px;flex-wrap:wrap;
  padding:14px 0 4px;font-size:12px;font-weight:700;color:#6B7280;
}
.ss22-trust-row span{
  display:inline-flex;align-items:center;gap:6px;
}
.ss22-trust-row span i{font-size:16px;color:#10b981}

/* ──────────────────────────────────────────────────────
   5. RECENTLY VIEWED COURSES WIDGET
   ────────────────────────────────────────────────────── */
.ss22-viewed{
  margin:0 0 32px;
}
.ss22-viewed-hd{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;gap:12px;
}
.ss22-viewed-hd h3{
  font-family:'Poppins',sans-serif;font-size:17px;font-weight:800;
  color:#15171C;letter-spacing:-.03em;margin:0;
}
.ss22-viewed-hd a{
  font-size:13px;font-weight:700;color:#E11D2A;text-decoration:none;
  display:inline-flex;align-items:center;gap:5px;
}
.ss22-viewed-scroll{
  display:flex;gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding-bottom:4px;
}
.ss22-viewed-scroll::-webkit-scrollbar{display:none}
.ss22-viewed-card{
  flex:0 0 210px;scroll-snap-align:start;
  border:1px solid #E8E8EC;border-radius:16px;
  background:#fff;overflow:hidden;
  text-decoration:none;color:#15171C;
  transition:transform .18s,box-shadow .18s,border-color .18s;
  display:block;
}
.ss22-viewed-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 36px rgba(20,23,28,.10);
  border-color:rgba(225,29,42,.18);
}
.ss22-viewed-thumb{
  height:118px;background:#1a1f2b;
  overflow:hidden;position:relative;
}
.ss22-viewed-thumb img{
  width:100%;height:100%;object-fit:cover;
  display:block;transition:transform .36s;
}
.ss22-viewed-card:hover .ss22-viewed-thumb img{transform:scale(1.05)}
.ss22-viewed-body{padding:12px}
.ss22-viewed-cat{
  font-size:10.5px;font-weight:800;color:#E11D2A;
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;
}
.ss22-viewed-title{
  font-size:13.5px;font-weight:700;color:#15171C;
  line-height:1.35;margin-bottom:8px;
  display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;
}
.ss22-viewed-price{
  font-family:'Poppins',sans-serif;font-size:14px;
  font-weight:800;color:#15171C;
}
@media(max-width:600px){
  .ss22-viewed-card{flex:0 0 180px}
}

/* ──────────────────────────────────────────────────────
   6. COUPON CODE FIELD (cart)
   ────────────────────────────────────────────────────── */
.ss22-coupon-row{
  display:flex;gap:8px;margin:16px 0;
}
.ss22-coupon-row input{
  flex:1;border:1.5px solid #E8E8EC;border-radius:10px;
  padding:11px 14px;font-size:14px;font-family:inherit;
  outline:none;background:#fff;
  transition:border-color .16s,box-shadow .16s;
  text-transform:uppercase;letter-spacing:.06em;
}
.ss22-coupon-row input::placeholder{text-transform:none;letter-spacing:0}
.ss22-coupon-row input:focus{border-color:#E11D2A;box-shadow:0 0 0 3px rgba(225,29,42,.08)}
.ss22-coupon-row button{
  flex-shrink:0;border:0;border-radius:10px;
  background:#15171C;color:#fff;
  font-weight:800;font-size:13px;
  padding:0 16px;cursor:pointer;
  transition:background .14s;font-family:inherit;
}
.ss22-coupon-row button:hover{background:#E11D2A}
.ss22-coupon-msg{font-size:12.5px;margin-top:4px;padding:0 2px}
.ss22-coupon-msg.ok{color:#059669}
.ss22-coupon-msg.err{color:#DC2626}


/* ══ ss-clean-2026.css ══ */
/* ═══════════════════════════════════════════════════════════════
   SKILL SAKHI — CLEAN PUBLIC DESIGN SYSTEM  (ss-clean-2026)
   One coherent, professional theme for every public page.
   Loaded LAST so it is the single source of truth — it supersedes
   the older layered "phase / polish / fix" stylesheets.
   Style: Clean & professional — white UI, brand red, soft cards,
   dark hero + dark footer. No backend / markup / data changes.
   ═══════════════════════════════════════════════════════════════ */

/* ── 1. DESIGN TOKENS (override every legacy alias) ─────────────── */
:root{
  /* Brand — Skill Sakhi red (professional education-marketplace theme) */
  --rd:#E30613; --rd2:#B9000F; --rd-l:#FF4D5A; --rd-pale:#FFF0F2; --rd-glass:rgba(227,6,19,.08);
  --pr:#E30613; --pr-d:#B9000F; --pr-l:#FF4D5A; --pr-pale:#FFF0F2; --pr-glass:rgba(227,6,19,.08);
  --red:#E30613; --red-pale:#FFF0F2; --accent:#E30613; --primary:#E30613;
  --brand:#E30613;

  /* Ink / neutrals */
  --bk:#101828; --bk2:#1D2939; --bk3:#344054;
  --ink:#101828; --ink-3:#344054; --dk:#101828; --dk-2:#1D2939; --dk-3:#344054; --tx:#101828; --tx2:#1D2939;
  --gr:#667085; --gr2:#98A2B3; --muted:#667085; --tx3:#667085; --tx4:#98A2B3;

  /* Surfaces / borders */
  --wh:#FFFFFF; --white:#FFFFFF;
  --cr:#F6F8FB; --cr2:#EEF3F9; --bg:#F6F8FB; --bg2:#EEF3F9; --off-white:#F6F8FB; --warm-gray:#F6F8FB;
  --bd:#E6EAF0; --bd2:#D0D7E2; --line:#E6EAF0;

  /* Support colors */
  --green:#058453; --green-pale:#EAF7EF; --gold:#F5A524; --gold-l:#FFC24D; --blue:#0B63E6;

  /* Type — Inter across the theme */
  --display:'Inter',system-ui,sans-serif; --font-display:'Inter',system-ui,sans-serif;
  --font-head:'Inter',system-ui,sans-serif; --head:'Inter',system-ui,sans-serif; --serif:'Inter',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif; --sans:'Inter',system-ui,sans-serif; --font-body:'Inter',system-ui,sans-serif;

  /* Radius */
  --r-xs:6px; --r-sm:8px; --r:10px; --r-lg:14px; --r-xl:18px; --r-2xl:24px; --r-pill:100px;
  --radius:10px; --radius-sm:8px; --radius-lg:14px; --radius-xl:18px;

  /* Shadows — soft & low */
  --sh-xs:0 1px 3px rgba(20,23,28,.05);
  --sh-sm:0 4px 14px rgba(20,23,28,.06);
  --sh-md:0 10px 28px rgba(20,23,28,.08);
  --sh-lg:0 18px 44px rgba(20,23,28,.10);
  --sh-xl:0 28px 64px rgba(20,23,28,.12);
  --sh-pr:0 8px 22px rgba(225,29,42,.24);
  --sh-gld:0 8px 22px rgba(245,166,35,.22);
  --shadow-sm:0 4px 14px rgba(20,23,28,.06); --shadow-md:0 10px 28px rgba(20,23,28,.08); --shadow-lg:0 18px 44px rgba(20,23,28,.10);

  /* Layout / motion */
  --wrap:1220px; --gap:24px; --sec:96px; --sec-sm:60px;
  --t:.2s cubic-bezier(.22,.61,.36,1); --transition:.2s cubic-bezier(.22,.61,.36,1); --ease:cubic-bezier(.22,.61,.36,1);
}

/* ── 2. BASE ────────────────────────────────────────────────────── */
body{font-family:var(--body);font-size:16.5px;line-height:1.7;color:var(--ink);background:#fff;-webkit-font-smoothing:antialiased;letter-spacing:0}
h1,h2,h3,h4,h5,h6,.t-display,.t-h1,.t-h2,.t-h3,.sec-title,.ss-heading,.ph-h1,
.sec-bar-left .title,.logo-name,.logo-text,.logo-inner,.ft-logo-name{
  font-family:var(--display)!important;letter-spacing:-.02em;color:var(--ink)}
.t-display,.t-h1,.sec-title,.ss-heading,.sec-bar-left .title,.ph-h1{font-weight:800!important;line-height:1.08}
.t-serif{font-family:var(--display)!important;font-style:normal}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(227,6,19,.16)}
.wrap,.ss-wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gap)}
.sec,.ss-sec{padding:var(--sec) 0}
.sec-sm,.ss-sec-sm{padding:var(--sec-sm) 0}
.ss-bg,.sec-bg{background:var(--cr)}

/* ── 3. NAVBAR ──────────────────────────────────────────────────── */
.ss-nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .25s,box-shadow .25s}
.ss-nav.scrolled{border-color:var(--bd);box-shadow:0 4px 20px rgba(20,23,28,.05)}
.nav-inner{max-width:var(--wrap);margin:0 auto;padding:0 var(--gap);height:74px;display:flex;align-items:center;gap:18px}
.nav-logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.ss-brand-logo,.ft-logo-img{height:42px;width:auto;object-fit:contain}
.logo-mark{width:40px;height:40px;background:var(--ink);border-radius:11px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.logo-mark::after{content:'';position:absolute;top:8px;right:8px;width:7px;height:7px;background:var(--brand);border-radius:50%}
.logo-inner{font-size:1.05rem;font-weight:800;color:#fff}
.logo-name,.logo-text{font-size:1.22rem;font-weight:800;color:var(--ink);letter-spacing:-.03em}
.logo-name span,.logo-text span{color:var(--rd)}
.logo-tag{font-size:.56rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--gr2)}
.nav-links{display:flex;align-items:center;gap:2px;margin:0 auto;list-style:none;padding:0}
.nav-links>li>a{position:relative;padding:9px 13px;font-size:13px;font-weight:800;color:#2A3444;transition:color var(--t);display:flex;align-items:center;gap:5px;white-space:nowrap}
.nav-links>li>a::after{content:'';position:absolute;left:13px;right:13px;bottom:0;height:3px;border-radius:999px;background:var(--rd);transform:scaleX(0);transition:transform .2s ease}
.nav-links>li>a:hover{color:var(--rd)}
.nav-links>li>a:hover::after,.nav-links>li>a.active::after{transform:scaleX(1)}
.nav-links>li>a.active{color:var(--rd)}
.nav-drop{display:none;position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);
  background:#fff;border:1px solid var(--bd);border-radius:16px;padding:10px;min-width:520px;box-shadow:var(--sh-lg);z-index:901}
.nav-more-drop{left:auto;right:0;transform:none;min-width:290px}
.nav-has-drop:hover .nav-drop{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.nav-has-drop:hover .nav-more-drop{display:grid;grid-template-columns:1fr}
.nav-drop-item{display:flex;align-items:flex-start;gap:11px;padding:12px;border-radius:11px;transition:background var(--t)}
.nav-drop-item:hover{background:var(--cr)}
.nav-drop-ic{width:36px;height:36px;border-radius:9px;background:var(--rd-pale);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0;color:var(--rd)}
.nav-drop-label{font-size:.9rem;font-weight:700;color:var(--ink)}
.nav-drop-sub{font-size:.76rem;color:var(--gr2);margin-top:1px}
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.ss-nav-search{position:relative;width:240px}
.ss-nav-search input{width:100%;padding:10px 38px 10px 15px;border:1px solid var(--bd);border-radius:var(--r-pill);font-size:.86rem;font-family:var(--body);background:var(--cr);outline:none;transition:border-color var(--t),background var(--t)}
.ss-nav-search input:focus{border-color:var(--rd);background:#fff}
.ss-nav-search button{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gr2);cursor:pointer;font-size:1rem;padding:6px}
.ss-cart{position:relative;width:42px;height:42px;border-radius:11px;border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:1.15rem;transition:border-color var(--t),color var(--t)}
.ss-cart:hover{border-color:var(--rd);color:var(--rd)}
.ss-cart span{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;background:var(--rd);color:#fff;border-radius:9px;font-size:.66rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.nav-ham{display:none;width:44px;height:44px;border-radius:11px;background:#fff;border:1px solid var(--bd);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.nav-ham span{display:block;width:19px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}

/* Mobile nav */
.mob-nav{position:fixed;inset:0;background:#fff;z-index:950;transform:translateX(100%);transition:transform .32s var(--ease);overflow-y:auto}
.mob-nav.open{transform:translateX(0)}
.mob-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--bd)}
.mob-close{width:44px;height:44px;border:1px solid var(--bd);border-radius:11px;background:#fff;cursor:pointer;font-size:1.15rem;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.mob-body{padding:20px 22px}
.mob-link{display:flex;align-items:center;justify-content:space-between;padding:15px 0;border-bottom:1px solid var(--bd);font-size:1.02rem;font-weight:600;color:var(--ink)}
.mob-link:hover{color:var(--rd)}

/* ── 4. BUTTONS ─────────────────────────────────────────────────── */
.btn-ss,.btn-pr,.btn-rd,.btn-bk,.btn-out,.btn-dk,.btn-out-w,.btn-wa,.btn-gold,
.btn-ss-primary,.btn-ss-outline,.btn-ss-outline-w,.btn-ss-gold,.btn-ss-wa{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--body);font-weight:800;font-size:13px;line-height:1;letter-spacing:.01em;
  padding:13px 22px;border-radius:8px;border:1px solid transparent;cursor:pointer;
  transition:transform var(--t),background var(--t),box-shadow var(--t),color var(--t),border-color var(--t);white-space:nowrap}
.btn-rd,.btn-pr,.btn-ss-primary{background:var(--rd);color:#fff;box-shadow:none}
.btn-rd:hover,.btn-pr:hover,.btn-ss-primary:hover{background:var(--rd2);color:#fff;transform:translateY(-1px);box-shadow:var(--sh-pr)}
.btn-bk{background:var(--ink);color:#fff}
.btn-bk:hover{background:var(--bk2);color:#fff;transform:translateY(-1px)}
.btn-out,.btn-dk,.btn-ss-outline{background:#fff;color:var(--ink);border-color:var(--bd2)}
.btn-out:hover,.btn-dk:hover,.btn-ss-outline:hover{border-color:var(--ink);background:var(--ink);color:#fff;transform:translateY(-1px)}
.btn-out-w,.btn-ss-outline-w{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-out-w:hover,.btn-ss-outline-w:hover{background:#fff;color:var(--ink)}
.btn-gold,.btn-ss-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover,.btn-ss-gold:hover{background:var(--gold-l);transform:translateY(-1px)}
.btn-wa,.btn-ss-wa{background:#25D366;color:#fff}
.btn-wa:hover,.btn-ss-wa:hover{background:#1BB954;color:#fff;transform:translateY(-1px)}
.btn-lg{padding:16px 32px;font-size:.96rem;border-radius:12px}
.btn-sm{padding:10px 18px;font-size:.82rem}

/* ── 5. SECTION HEADERS / TYPOGRAPHY ────────────────────────────── */
.t-label,.sec-eyebrow,.ss-sec-label,.hp-eyebrow,.sec-bar-left .label,.ph-eye,.ss15-rail-kicker{
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--rd)}
.sec-title,.ss-heading{font-size:clamp(1.7rem,3.2vw,2.6rem);line-height:1.1;font-weight:800;color:var(--ink)}
.sec-title em,.ss-heading em,.sec-bar-left .title em{color:var(--rd);font-style:normal}
.sec-sub,.ss-sub,.hp-sub{font-size:1.02rem;color:var(--gr);line-height:1.7;max-width:600px}
.sec-hd{margin-bottom:48px}
.sec-bar,.sec-hd-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding-bottom:22px;border-bottom:1px solid var(--bd);margin-bottom:44px}
.sec-bar-left .title{font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1.1}

/* ── 6. CARDS ───────────────────────────────────────────────────── */
.card-ss,.cdx-card,.tile,.course-card,.ss-card{
  background:#fff;border:1px solid var(--bd)!important;border-radius:16px!important;overflow:hidden;
  box-shadow:var(--sh-sm);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.card-ss:hover,.cdx-card:hover,.tile:hover,.course-card:hover,.ss-card:hover{
  transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent!important}
.card-bk{background:var(--bk2);border:1px solid rgba(255,255,255,.08);border-radius:16px;color:#fff}

/* ── 7. HERO (inner pages) — refined dark ───────────────────────── */
.page-hero{background:var(--ink);padding:66px 0;position:relative;overflow:hidden;color:#fff}
.page-hero::before{content:'';position:absolute;top:-140px;right:-120px;width:440px;height:440px;border-radius:50%;
  background:radial-gradient(circle,rgba(225,29,42,.18),transparent 66%);pointer-events:none}
.page-hero-sm{padding:44px 0}
.ph-eye{color:#FF6B70;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.ph-h1{font-size:clamp(2rem,4vw,3.1rem);font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.08;margin-bottom:14px}
.ph-h1 em{color:#FF6B70;font-style:normal}
.ph-sub{color:rgba(255,255,255,.62);font-size:1.02rem;max-width:560px;line-height:1.7}

/* ── 8. FORMS ───────────────────────────────────────────────────── */
.input-ss,.field input,.field select,.field textarea,
.ss15-field input,.ss15-field textarea,.ss22-exit-field input{
  width:100%;padding:13px 15px;border:1.5px solid var(--bd);border-radius:11px;
  font-family:var(--body);font-size:.94rem;color:var(--ink);background:#fff;outline:none;
  transition:border-color var(--t),box-shadow var(--t)}
.input-ss:focus,.field input:focus,.field select:focus,.field textarea:focus,
.ss15-field input:focus,.ss15-field textarea:focus,.ss22-exit-field input:focus{
  border-color:var(--rd);box-shadow:0 0 0 3px rgba(225,29,42,.10)}
.input-ss::placeholder{color:var(--gr2)}
textarea.input-ss{resize:vertical;min-height:120px}
.form-label,.ss-label,.ss15-field label,.ss22-exit-field label{display:block;font-size:.82rem;font-weight:700;color:#374151;margin-bottom:7px}
.form-group{margin-bottom:18px}
.form-hint{font-size:.77rem;color:var(--gr2);margin-top:5px}

/* ── 9. CHIPS / BADGES / TAGS / ALERTS ──────────────────────────── */
.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-pill);
  border:1.5px solid var(--bd);font-size:.83rem;font-weight:600;cursor:pointer;color:var(--gr);background:#fff;transition:all var(--t)}
.chip:hover,.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip.rd:hover,.chip.rd.active{background:var(--rd);border-color:var(--rd);color:#fff}
.chips-row{display:flex;gap:9px;flex-wrap:wrap}
.tag-ss,.badge-ss,.tag-rd{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;font-size:.72rem;font-weight:700;letter-spacing:.03em;border-radius:8px}
.tag-rd,.badge-ss{background:var(--rd-pale);color:var(--rd);border:1px solid rgba(225,29,42,.18)}
.tag-bk{background:var(--ink);color:#fff}
.tag-cr{background:var(--cr2);color:var(--ink)}
.stars{color:var(--gold);letter-spacing:1px}
.alert-ss{padding:14px 18px;border-radius:11px;font-size:.9rem;margin-bottom:16px;border:1px solid;display:flex;align-items:flex-start;gap:10px}
.alert-ss.success{background:var(--green-pale);color:#15803D;border-color:#BBE7C9}
.alert-ss.error{background:var(--rd-pale);color:var(--rd2);border-color:#F7C1C1}
.alert-ss.info{background:#EFF4FF;color:#1D4ED8;border-color:#C7DAFE}
.alert-ss.warning{background:#FFF8EB;color:#92400E;border-color:#FAE0A6}
.empty-pg{text-align:center;padding:72px 20px;color:var(--gr)}
.empty-pg i{font-size:2.6rem;opacity:.28;display:block;margin-bottom:14px}
.empty-pg h3{font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.prog-fill{background:var(--rd)}

/* ── 10. TRUST BAR / PAGE BAND / PRE-FOOTER (ss12) ──────────────── */
.ss12-trustbar{background:#fff;border-bottom:1px solid var(--bd);padding:8px 24px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;font-size:12px;color:var(--gr)}
.ss12-trustbar strong{color:var(--ink);font-weight:700}
.ss12-trust-items{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}
.ss12-trust-items span{display:inline-flex;align-items:center;gap:6px}
.ss12-trust-items i{color:var(--rd)}
.ss12-page-band{max-width:var(--wrap);margin:28px auto;padding:26px 30px;background:var(--cr);border:1px solid var(--bd);border-radius:18px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.ss12-page-band h3{font-size:1.25rem;font-weight:800;color:var(--ink);margin-bottom:5px}
.ss12-page-band p{font-size:.92rem;color:var(--gr);max-width:640px;margin:0}
.ss12-band-actions,.ss12-prefooter-actions{display:flex;gap:12px;flex-wrap:wrap}
.ss12-band-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:11px;font-weight:700;font-size:.88rem;transition:transform var(--t),box-shadow var(--t),background var(--t)}
.ss12-band-btn.red{background:var(--rd);color:#fff}
.ss12-band-btn.red:hover{background:var(--rd2);transform:translateY(-1px);box-shadow:var(--sh-pr)}
.ss12-band-btn.light{background:#fff;color:var(--ink);border:1.5px solid var(--bd2)}
.ss12-band-btn.light:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.ss12-prefooter{max-width:var(--wrap);margin:0 auto 8px;padding:56px 40px;background:var(--ink);border-radius:24px;
  display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative;overflow:hidden}
.ss12-prefooter::before{content:'';position:absolute;top:-120px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(225,29,42,.2),transparent 66%)}
.ss12-prefooter h2{font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:800;color:#fff;margin-bottom:8px;position:relative}
.ss12-prefooter p{font-size:.96rem;color:rgba(255,255,255,.6);max-width:560px;margin:0;position:relative}
.ss12-prefooter-actions{position:relative}
.ss12-floating-whatsapp{position:fixed;bottom:24px;right:24px;z-index:800;width:56px;height:56px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#fff;box-shadow:0 8px 24px rgba(37,211,102,.4);transition:transform var(--t)}
.ss12-floating-whatsapp:hover{transform:scale(1.08);color:#fff}
.wa-float{background:#25D366}

/* ── 11. FOOTER — refined dark ──────────────────────────────────── */
.ss-footer{background:#141B26;color:rgba(255,255,255,.62)}
.footer-top{padding:72px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-grid{display:grid;grid-template-columns:1.9fr 1fr 1fr 1.5fr;gap:56px}
.ft-logo-mark{background:var(--rd);border-radius:11px}
.ft-logo-name{color:#fff;font-weight:800}
.ft-about{font-size:.9rem;line-height:1.8;color:rgba(255,255,255,.5);margin-bottom:22px;max-width:290px}
.ft-soc-btn{width:35px;height:35px;border:0;background:#212B3A;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;transition:all var(--t)}
.ft-soc-btn:hover{background:var(--rd);border-color:var(--rd);color:#fff;transform:translateY(-2px)}
.ft-cert{border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.45);border-radius:8px}
.ft-col h4,.ss-footer h4{font-size:.68rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:18px}
.ft-links a{font-size:.9rem;color:rgba(255,255,255,.55);transition:color var(--t)}
.ft-links a:hover{color:#fff}
.ft-links a:hover::before{background:var(--rd)}
.ft-contact-item{font-size:.9rem;color:rgba(255,255,255,.55)}
.ft-contact-item i{color:var(--rd)}
.ft-nl{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:12px}
.ft-nl-form button{background:var(--rd)}
.ft-nl-form button:hover{background:var(--rd2)}
.footer-bottom{padding:22px 0}
.ft-legal a:hover{color:#fff}

/* ── 12. CONVERSION RAIL / MODAL (ss15) ─────────────────────────── */
.ss15-rail{position:fixed;left:0;bottom:0;z-index:790}
.ss15-btn{display:inline-flex;align-items:center;gap:7px;padding:11px 20px;border-radius:11px;font-weight:700;font-size:.86rem;transition:transform var(--t),background var(--t),box-shadow var(--t)}
.ss15-btn.primary{background:var(--rd);color:#fff}
.ss15-btn.primary:hover{background:var(--rd2);transform:translateY(-1px);box-shadow:var(--sh-pr)}
.ss15-btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--bd2)}
.ss15-btn.ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.ss15-counselor{position:fixed;right:24px;bottom:90px;z-index:795;display:inline-flex;align-items:center;gap:9px;
  padding:12px 20px;border-radius:var(--r-pill);background:var(--ink);color:#fff;font-weight:700;font-size:.86rem;box-shadow:var(--sh-lg);transition:transform var(--t)}
.ss15-counselor:hover{transform:translateY(-2px);color:#fff}
.ss15-counselor i{color:#FF6B70}
.ss15-modal-card{border-radius:20px;overflow:hidden;box-shadow:var(--sh-xl)}
.ss15-modal-head h3{font-family:var(--display);font-weight:800;color:var(--ink)}
.ss15-close{border-radius:10px}
.ss15-submit{width:100%;justify-content:center;margin-top:6px}

/* ── 13. PROMO / EXIT MODALS (ss22 / banner) ────────────────────── */
.ss22-banner{background:var(--ink);color:#fff}
.ss22-banner-cta{background:var(--rd);color:#fff;border-radius:9px;font-weight:700}
.ss22-exit-submit,.ss22-preview-cta{background:var(--rd)!important;border-radius:11px!important}
.ss22-exit-card,.ss22-preview-box{border-radius:20px!important;overflow:hidden}
.ss22-exit-title{font-family:var(--display)!important;font-weight:800!important}

/* ── 14. ADMIN EDIT TOOLBAR (logged-in staff) ───────────────────── */
.public-edit-toolbar{position:fixed;bottom:16px;left:16px;z-index:780;display:flex;gap:8px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--bd);border-radius:14px;padding:8px;box-shadow:var(--sh-lg)}
.public-edit-toolbar a{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:9px;font-size:.8rem;font-weight:700;color:var(--gr);transition:all var(--t)}
.public-edit-toolbar a:hover{background:var(--cr);color:var(--ink)}
.public-edit-toolbar a.primary{background:var(--rd);color:#fff}
.public-edit-toolbar a.primary:hover{background:var(--rd2);color:#fff}

/* ── 15. SCROLL REVEAL (retain animation) ───────────────────────── */
.sr,.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.sr.in,.reveal.up{opacity:1;transform:translateY(0)}

/* ── 16. RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .nav-links{display:none!important}
  .nav-ham{display:flex!important}
  .ss-nav-search{display:none!important}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:768px){
  :root{--sec:60px;--sec-sm:42px;--gap:16px}
  body{font-size:16px}
  .nav-inner{height:62px}
  .page-hero{padding:48px 0}
  .ss12-prefooter{padding:38px 24px;border-radius:18px}
  .ss12-page-band{padding:22px;flex-direction:column;align-items:flex-start}
  .ss12-trustbar{display:none}
  .d-mob-hide{display:none!important}
  /* Clearance so fixed WhatsApp / counselor / edit buttons never overlap footer content */
  .ss-footer{padding-bottom:104px}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-bottom{flex-direction:column;text-align:center;gap:12px}
  .ss12-trustbar{font-size:.76rem;gap:12px}
  .ss15-rail{display:none}
}

/* ── 17. GLOBAL POLISH (accessibility + micro-interactions) ─────── */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid rgba(227,6,19,.35);outline-offset:2px;border-radius:8px}
html{scrollbar-color:#C9D1DD transparent;scrollbar-width:thin}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#C9D1DD;border-radius:99px;border:3px solid #fff}
::-webkit-scrollbar-thumb:hover{background:#98A2B3}
/* nav niceties */
.ss-nav .nav-logo{transition:opacity .2s}
.ss-nav .nav-logo:hover{opacity:.85}
.nav-actions .btn-rd{box-shadow:0 8px 20px rgba(227,6,19,.22)}
.nav-actions .btn-rd:hover{box-shadow:0 12px 26px rgba(227,6,19,.30)}
.ss-cart{transition:border-color .2s,color .2s,transform .2s}
.ss-cart:hover{transform:translateY(-1px)}
/* footer niceties */
.ft-links a{transition:color .2s,transform .2s;display:inline-flex}
.ft-links a:hover{transform:translateX(3px)}
.ft-soc-btn:hover{transform:translateY(-3px) scale(1.05)}
/* buttons press feel */
.btn-ss:active,.btn-pr:active,.btn-rd:active{transform:translateY(0) scale(.98)}
/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ── 18. COURSES CATALOG PAGE (marketplace skin — overrides legacy phase CSS;
        markup & JS in courses.php untouched) ─────────────────────── */
.phase16-catalog{background:linear-gradient(180deg,#F6F8FB,#F2F5FA);font-family:var(--body);color:var(--ink)}
.phase16-catalog .cl-wrap{width:min(1180px,calc(100% - 40px));margin-inline:auto;padding:0}
/* hero */
.phase16-catalog .cl-hero{padding:44px 0 26px;background:transparent;text-align:left}
.phase16-catalog .cl-title{font-family:var(--display);font-weight:900;font-size:clamp(30px,4vw,44px);letter-spacing:-.045em;color:var(--ink);margin:0}
.phase16-catalog .cl-title .dot{color:var(--rd)}
.phase16-catalog .cl-sub{color:var(--gr);font-size:14.5px;line-height:1.65;max-width:640px;margin:10px 0 0}
.phase16-catalog .phase16-hero-actions{margin-top:18px}
.phase16-catalog .phase16-hero-actions a{display:inline-flex;align-items:center;gap:8px;border-radius:8px;background:var(--ink);color:#fff;font-weight:800;font-size:13px;padding:12px 18px;transition:transform .18s,box-shadow .18s,background .18s;box-shadow:0 10px 24px rgba(16,24,40,.12)}
.phase16-catalog .phase16-hero-actions a:hover{transform:translateY(-2px);background:#020617}
.phase16-catalog .phase16-hero-actions a:last-child{background:#fff;color:var(--rd);border:1px solid var(--bd)}
.phase16-catalog .phase16-hero-actions a:last-child:hover{border-color:var(--rd)}
/* recently viewed strip */
.phase16-catalog .ss22-viewed{background:#fff;border:1px solid var(--bd);border-radius:16px;padding:16px 18px;box-shadow:var(--sh-sm);margin-bottom:18px}
.phase16-catalog .ss22-viewed-hd h3{font-family:var(--display);font-weight:900;color:var(--ink)}
.phase16-catalog .ss22-viewed-hd a{color:var(--rd);font-weight:800;font-size:13px}
/* layout */
.phase16-catalog .cl-layout{display:grid;grid-template-columns:272px minmax(0,1fr);gap:26px;align-items:start;padding-bottom:70px}
/* filters card */
.phase16-catalog .filters{background:#fff;border:1px solid var(--bd);border-radius:16px;padding:20px;box-shadow:var(--sh-sm)}
@media(min-width:901px){.phase16-catalog .filters{position:sticky;top:96px}}
.phase16-catalog .filters>h3{font-family:var(--display);font-weight:900;font-size:16px;color:var(--ink);margin:0 0 6px;letter-spacing:-.02em}
.phase16-catalog .filter-title{font-size:10.5px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--rd);margin:18px 0 8px;display:flex;align-items:center;gap:8px}
.phase16-catalog .filter-title::after{content:'';flex:1;height:1px;background:var(--bd)}
.phase16-catalog .filter-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 9px;margin:0 -9px;border-radius:9px;font-size:13px;font-weight:600;color:var(--gr);cursor:pointer;transition:background .15s,color .15s}
.phase16-catalog .filter-row:hover{background:var(--cr);color:var(--ink)}
.phase16-catalog .filter-row input{accent-color:var(--rd);width:15px;height:15px;margin-right:7px;cursor:pointer}
.phase16-catalog .filter-count{color:var(--gr2);font-size:11.5px;font-weight:800}
.phase16-catalog .phase16-clear{color:var(--rd);font-weight:900;font-size:12.5px}
.phase16-catalog .phase16-clear:hover{text-decoration:underline}
/* topbar */
.phase16-catalog .topbar{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.phase16-catalog .search-big{flex:1;display:flex;align-items:center;background:#fff;border:1px solid var(--bd);border-radius:11px;overflow:hidden;box-shadow:var(--sh-xs);transition:border-color .2s,box-shadow .2s}
.phase16-catalog .search-big:focus-within{border-color:var(--rd);box-shadow:0 0 0 4px rgba(227,6,19,.07)}
.phase16-catalog .search-big input{flex:1;min-width:0;border:0;outline:0;padding:13px 15px;font-size:13.5px;font-family:var(--body);color:var(--ink);background:transparent}
.phase16-catalog .search-big button{border:0;background:var(--ink);color:#fff;padding:0 18px;align-self:stretch;cursor:pointer;font-size:15px;transition:background .2s}
.phase16-catalog .search-big button:hover{background:var(--rd)}
.phase16-catalog .sort{border:1px solid var(--bd);border-radius:11px;background:#fff;color:var(--ink);font-family:var(--body);font-weight:700;font-size:12.5px;padding:12px 14px;cursor:pointer;box-shadow:var(--sh-xs);outline:none}
.phase16-catalog .sort:focus{border-color:var(--rd)}
.phase16-catalog .p21-filter-toggle{display:none;align-items:center;gap:8px;border:1px solid var(--bd);border-radius:11px;background:#fff;color:var(--ink);font-weight:800;font-size:13px;padding:12px 16px;cursor:pointer;box-shadow:var(--sh-xs)}
.phase16-catalog .p21-active-cnt{background:var(--rd);color:#fff;border-radius:999px;min-width:19px;height:19px;display:grid;place-items:center;font-size:10.5px;font-weight:900;padding:0 5px}
/* compare bar */
.phase16-catalog .phase16-compare-bar{background:linear-gradient(160deg,#12161E,#0B0F15);color:#fff;border-radius:16px;padding:16px 18px;margin-bottom:16px;box-shadow:0 18px 44px rgba(14,18,24,.18);border:1px solid rgba(255,255,255,.06)}
.phase16-catalog .phase16-compare-bar b{font-weight:900}
.phase16-catalog .phase16-compare-bar span{color:rgba(255,255,255,.62);font-size:12.5px}
.phase16-catalog .phase16-compare-bar button{border:0;border-radius:9px;background:var(--rd);color:#fff;font-weight:900;font-size:12.5px;padding:12px 18px;cursor:pointer;transition:background .2s,transform .18s;box-shadow:0 10px 22px rgba(227,6,19,.28)}
.phase16-catalog .phase16-compare-bar button:hover{background:var(--rd2);transform:translateY(-1px)}
/* course rows */
.phase16-catalog .course-list{display:flex;flex-direction:column;gap:16px}
.phase16-catalog .course-row{position:relative;display:grid;grid-template-columns:216px minmax(0,1fr) 196px;gap:18px;background:#fff;border:1px solid var(--bd);border-radius:16px;padding:16px;box-shadow:var(--sh-sm);transition:transform .22s var(--ease),box-shadow .22s,border-color .22s;overflow:hidden}
.phase16-catalog .course-row::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--rd),var(--rd-l));opacity:0;transition:opacity .22s}
.phase16-catalog .course-row:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:#D8DFEA}
.phase16-catalog .course-row:hover::before{opacity:1}
.phase16-catalog .course-thumb{border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#E9EEF6,#DCE5F1);aspect-ratio:16/10;position:relative}
.phase16-catalog .course-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.phase16-catalog .course-row:hover .course-thumb img{transform:scale(1.06)}
.phase16-catalog .course-info h3{margin:2px 0 7px}
.phase16-catalog .course-info h3 a{font-family:var(--display);font-weight:900;font-size:17px;line-height:1.32;color:var(--ink);letter-spacing:-.02em;transition:color .18s}
.phase16-catalog .course-info h3 a:hover{color:var(--rd)}
.phase16-catalog .course-info p{color:var(--gr);font-size:13px;line-height:1.62;margin:0 0 12px}
.phase16-catalog .course-tags{display:flex;flex-wrap:wrap;gap:7px}
.phase16-catalog .course-tags span{background:var(--cr);border:1px solid var(--bd);color:var(--gr);border-radius:999px;padding:5px 11px;font-size:10.5px;font-weight:800}
.phase16-catalog .course-side{display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start;gap:8px;border-left:1px solid var(--bd);padding-left:16px}
.phase16-catalog .p21-cbadge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 11px;font-size:10px;font-weight:900;letter-spacing:.02em;background:var(--rd-pale);color:var(--rd)}
.phase16-catalog .p21-badge-new{background:#EAF7EF;color:#058453}
.phase16-catalog .p21-badge-popular{background:#FFF6E6;color:#B77400}
.phase16-catalog .p21-badge-women{background:#FDEBF3;color:#C0246E}
.phase16-catalog .p21-badge-featured{background:#EEF4FF;color:#155EEF}
.phase16-catalog .rating{display:inline-flex;align-items:center;gap:5px;color:var(--ink);font-weight:900;font-size:13px}
.phase16-catalog .rating i{color:var(--gold)}
.phase16-catalog .price{font-family:var(--display);font-weight:900;font-size:21px;letter-spacing:-.03em;color:var(--ink)}
.phase16-catalog .mini-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;margin-top:auto}
.phase16-catalog .ss22-preview-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--bd);border-radius:8px;background:#fff;color:var(--ink);font-weight:800;font-size:11.5px;padding:9px 13px;cursor:pointer;transition:border-color .18s,color .18s}
.phase16-catalog .ss22-preview-btn:hover{border-color:var(--rd);color:var(--rd)}
/* compare checkbox on thumb */
.phase16-catalog .phase16-compare-check span{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.95);color:var(--ink);border:1px solid var(--bd);box-shadow:var(--sh-sm);transition:all .18s}
.phase16-catalog .phase16-compare-check:hover span{border-color:var(--rd);color:var(--rd)}
.phase16-catalog .phase16-compare-check input:checked+span{background:var(--rd);color:#fff;border-color:var(--rd)}
/* empty state */
.phase16-catalog .p21-empty{background:#fff;border:1px dashed var(--bd2);border-radius:16px;text-align:center;padding:60px 24px;color:var(--gr)}
.phase16-catalog .p21-empty-icon{width:64px;height:64px;border-radius:16px;background:var(--rd-pale);color:var(--rd);display:grid;place-items:center;font-size:30px;margin:0 auto 16px}
.phase16-catalog .p21-empty h3{font-family:var(--display);font-weight:900;color:var(--ink);margin-bottom:8px}
.phase16-catalog .p21-empty p{font-size:13.5px;line-height:1.65;max-width:480px;margin:0 auto 20px}
.phase16-catalog .p21-ea-primary{display:inline-flex;align-items:center;gap:7px;background:var(--rd);color:#fff;border-radius:9px;padding:12px 18px;font-weight:800;font-size:13px;margin:0 5px}
.phase16-catalog .p21-ea-ghost{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--ink);border:1px solid var(--bd);border-radius:9px;padding:12px 18px;font-weight:800;font-size:13px;margin:0 5px}
/* pager */
.phase16-catalog .pager{display:flex;gap:8px;justify-content:center;margin-top:26px}
.phase16-catalog .pager a,.phase16-catalog .pager span{min-width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--bd);background:#fff;color:var(--gr);font-weight:800;font-size:13px;transition:all .18s;padding:0 12px}
.phase16-catalog .pager a:hover{border-color:var(--rd);color:var(--rd);transform:translateY(-1px)}
.phase16-catalog .pager span.active{background:var(--rd);border-color:var(--rd);color:#fff;box-shadow:0 8px 18px rgba(227,6,19,.24)}
/* responsive */
@media(max-width:1024px){
  .phase16-catalog .cl-layout{grid-template-columns:1fr}
  .phase16-catalog .p21-filter-toggle{display:inline-flex}
}
@media(max-width:900px){
  .phase16-catalog .filters{border-radius:0 16px 16px 0}
}
@media(max-width:760px){
  .phase16-catalog .course-row{grid-template-columns:1fr;gap:12px}
  .phase16-catalog .course-thumb{aspect-ratio:16/9}
  .phase16-catalog .course-side{border-left:0;border-top:1px solid var(--bd);padding-left:0;padding-top:12px;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:space-between}
  .phase16-catalog .mini-actions{justify-content:flex-start;width:100%}
  .phase16-catalog .topbar{flex-wrap:wrap}
  .phase16-catalog .search-big{order:3;flex-basis:100%}
  .phase16-catalog .cl-hero{padding:30px 0 20px}
}

/* ── 19. COURSE DETAIL PAGE (re-tokens cdp-2026.css to the marketplace
        theme — loads last, so these win; markup untouched) ────────── */
.cdp{
  --r:#E30613;--r2:#B9000F;--r3:#B9000F;
  --ink:#101828;--ink2:#1D2939;--mut:#667085;
  --soft:#F6F8FB;--line:#E6EAF0;--card:#FFFFFF;
  --gold:#F5A524;
  font-family:Inter,system-ui,sans-serif;
}
.cdp h1,.cdp h2,.cdp h3,.cdp h4{font-family:Inter,system-ui,sans-serif;letter-spacing:-.035em;font-weight:900}
.cdp-rev-big,.cdp-price-now,.cdp-rel-price{font-family:Inter,system-ui,sans-serif;font-weight:900;letter-spacing:-.03em}
/* hero strip → theme dark with red glow */
.cdp-hero-strip{background:linear-gradient(160deg,#12161E 0%,#0B0F15 58%,#20070A 130%);border-radius:20px;position:relative;overflow:hidden}
.cdp-hero-strip::after{content:'';position:absolute;right:-90px;top:-110px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(227,6,19,.30),transparent 65%);pointer-events:none}
.cdp-hero-strip>*{position:relative;z-index:1}
/* media fallbacks → theme dark */
.cdp-buy-thumb{background:linear-gradient(150deg,#1C2736,#0B1524)}
.cdp-rel-thumb{background:linear-gradient(150deg,#1C2736,#0B1524)}
/* buy card premium finish */
.cdp-buy{border:1px solid var(--line);border-radius:18px;box-shadow:0 24px 60px rgba(16,24,40,.14);overflow:hidden}
.cdp-buy .cdp-btn{border-radius:9px;font-weight:800;transition:transform .18s,box-shadow .18s,background .18s}
.cdp-buy .cdp-btn:hover{transform:translateY(-2px)}
/* tabs / pills — red accent */
.cdp-tab{font-weight:800;transition:color .18s}
.cdp-tab:hover{color:var(--r)}
.cdp-pill{border-radius:999px;font-weight:800}
/* cards & panels — unified radius/shadow */
.cdp-panel,.cdp-instructor-card,.cdp-review,.cdp-rel-card,.cdp-rev-summary,.cdp-review-form{border-radius:16px}
.cdp-rel-card{transition:transform .22s cubic-bezier(.22,.61,.36,1),box-shadow .22s,border-color .22s}
.cdp-rel-card:hover{transform:translateY(-5px);box-shadow:0 22px 48px rgba(16,24,40,.14)}
/* accordion rows */
.cdp-mod{border-radius:14px;overflow:hidden}
.cdp-lesson{transition:background .15s}
.cdp-lesson:hover{background:var(--soft)}
/* breadcrumb + trust */
.cdp-bc a:hover{color:var(--r)}
.cdp-trust{font-weight:700}
/* CTA band inside page */
.cdp-cta-band{border-radius:18px;background:linear-gradient(160deg,#12161E,#0B0F15)}
/* mobile sticky bar */
.cdp-mbar{backdrop-filter:blur(12px)}

/* ── 20. LOGIN PAGE refinements (loginref is already on-theme; this
        aligns neutrals and adds micro-interactions) ───────────────── */
.loginref{--ink:#101828;--muted:#667085;--line:#E6EAF0}
.loginref .lr-crumb{color:var(--gr)}
.loginref .lr-card{border-color:var(--bd)}
.loginref .lr-left{background:radial-gradient(circle at 82% 66%,rgba(227,6,19,.42),transparent 34%),linear-gradient(150deg,#20070A,#0B0F15 55%,#101B2C)}
.loginref .lr-left h1{letter-spacing:-.05em}
.loginref .control input{border-radius:9px;font-family:var(--body)}
.loginref .control input:focus{box-shadow:0 0 0 4px rgba(227,6,19,.08)}
.loginref .login-btn{border-radius:9px;cursor:pointer;transition:transform .18s,box-shadow .18s,background .18s}
.loginref .login-btn:hover{background:#B9000F;transform:translateY(-2px);box-shadow:0 18px 38px rgba(227,6,19,.30)}
.loginref .login-btn:active{transform:translateY(0) scale(.99)}
.loginref .social{border-radius:9px;cursor:pointer;transition:border-color .18s,transform .18s,box-shadow .18s}
.loginref .social:hover{border-color:#101828;transform:translateY(-1px);box-shadow:0 10px 24px rgba(16,24,40,.08)}
.loginref .lr-stats{background:#fff;border:1px solid var(--bd);box-shadow:0 16px 50px rgba(16,24,40,.06)}
.loginref .lr-stat{border-right-color:var(--bd)}
.loginref .lr-num{letter-spacing:-.03em}
.loginref .signup a:hover,.loginref .label-row a:hover{text-decoration:underline}
@media(max-width:640px){.loginref .lr-stat{border-bottom-color:var(--bd)}}

/* ═══════════════════════════════════════════════════════════════
   §21  PUBLIC PAGE POLISH 2.0 — marketplace band heroes, reveal
        stagger, interaction depth. Applies to every public page.
   ═══════════════════════════════════════════════════════════════ */

/* ── Page hero: match the home marketplace band ── */
.page-hero{
  background:linear-gradient(180deg,#12161E 0%,#0E1218 100%);
  border-bottom:2px solid var(--rd);
  padding:72px 0 64px;
}
.page-hero::before{
  background:radial-gradient(circle,rgba(227,6,19,.14) 0%,rgba(227,6,19,0) 62%);
  width:520px;height:520px;top:-180px;right:-140px;
}
.page-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:26px 26px;
}
.page-hero .wrap{position:relative;z-index:1}
.page-hero-sm{padding:50px 0 44px}
.ph-eye{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(227,6,19,.12);border:1px solid rgba(227,6,19,.35);
  color:#FF6B70;font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  padding:7px 14px;border-radius:999px;margin-bottom:18px;
}
.ph-eye i{font-size:.9rem}
.ph-h1{letter-spacing:-.03em}
.ph-h1 em{color:#FF4D5A}
.ph-sub{color:rgba(255,255,255,.66)}

/* ── Reveal stagger (usable on any page) ── */
.sr-d1{transition-delay:.06s}
.sr-d2{transition-delay:.12s}
.sr-d3{transition-delay:.18s}
.sr-d4{transition-delay:.24s}
.sr-d5{transition-delay:.3s}

/* ── Button interaction depth ── */
.btn-ss:active,.btn-pr:active,.btn-rd:active,.btn-bk:active,.btn-out:active,.btn-dk:active,
.btn-wa:active,.btn-gold:active{transform:translateY(0) scale(.985)}
.btn-ss,.btn-pr,.btn-rd,.btn-bk,.btn-out,.btn-dk,.btn-wa,.btn-gold{will-change:transform}

/* ── Empty states: soft red icon disc + inviting copy ── */
.empty-pg{padding:84px 20px}
.empty-pg i{
  font-size:1.9rem;opacity:1;color:var(--rd);
  width:72px;height:72px;line-height:72px;margin:0 auto 18px;
  background:var(--rd-pale);border:1px solid rgba(227,6,19,.15);border-radius:50%;
}
.empty-pg p a{color:var(--rd);font-weight:700}
.empty-pg p a:hover{text-decoration:underline}

/* ── Anchors land clear of the sticky nav ── */
section[id],[id^="sec-"],h2[id],h3[id]{scroll-margin-top:96px}

/* ── Cards: consistent lift + image rendering across pages ── */
.bc,.wbc,.wcard,.rm-card,.course-pick{-webkit-tap-highlight-color:transparent}
.bc img,.wbc img,.wcard img,.feat-img img{backface-visibility:hidden}

/* ── Chips: red accent for active filters on light pages ── */
.chips-row .chip.active{background:var(--rd);border-color:var(--rd);color:#fff}
.chips-row .chip.active:hover{background:var(--rd2);border-color:var(--rd2)}

/* ── Breadcrumbs inside dark heroes ── */
.page-hero a{transition:color .15s}

/* ── Section rhythm on small screens ── */
@media(max-width:640px){
  .sec,.ss-sec{padding:52px 0}
  .page-hero{padding:52px 0 46px}
  .page-hero-sm{padding:40px 0 36px}
  .ph-sub{font-size:.94rem}
}

/* ── Reduced motion: stagger off too ── */
@media(prefers-reduced-motion:reduce){
  .sr-d1,.sr-d2,.sr-d3,.sr-d4,.sr-d5{transition-delay:0s}
}

