@import url("https://fonts.googleapis.com/css?family=PT+Sans:300,400,700|Open+Sans:300,400,700");

      :root {
        --font: PT Sans;
        --alt-font: Open Sans;
        --accent-color: #009cde;
        --secondary-color: #3f9c35;
        --link-color: #009cde;
        --accent-highlight-color: #00425f;
        --accent-highlight-background-color: #c4eeff;
        --accent-tinted-color-70: #b3e1f5;
        --accent-tinted-color-80: #ccebf8;
        --accent-tinted-color-90: #e6f5fc;
        --accent-contrast-color: #fff;
        --accent-contrast-tinted-background-color: #b3b3b3;
        --accent-hover-color: #12b9ff;
        --secondary-hover-color: #50c044;
        --secondary-contrast-color: #fff;
        --link-hover-color: #45c8ff;
      }
      
body { background: url('https://d36ai2hkxl16us.cloudfront.net/thoughtindustries/image/upload/v1/course-uploads/f0d7e685-a985-49bd-bc32-1f28afb7e322/14qryrjydw92-GradiantGrey1_1500.png'); background-attachment: fixed; background-size: cover; }
.company__logo {text-indent: 100%;white-space: nowrap;overflow: hidden;background: url('https://d36ai2hkxl16us.cloudfront.net/thoughtindustries/image/upload/a_exif,c_fit,t_ti_company_logo_v4/v1/course-uploads/f0d7e685-a985-49bd-bc32-1f28afb7e322/n3ctp9ge7p2c-HeaderLogo.jpg') no-repeat center left;background-size: contain;} .company__logo span.h4 {visibility: hidden;}
/* =============================
   RSM Academy – Base Theme (CSS only)
   ============================= */

:root{
  --bg:#0b1020;
  --surface:#0f172a;
  --text:#0b0f1a;
  --ink:#0a0e19;
  --muted:#5b6477;

  --primary:#15a748;
  --primary-700:#0c9d7a;
  --primary-900:#07725a;
  --emerald-50:#eafff7;

  --accent-blue:#009cde;
  --accent-orange:#ff9a3e;
  --accent-pink:#ff6fae;
  --accent-violet:#7b61ff;

  --card:#ffffff;
  --card-2:#f7f9fc;
  --ring:rgba(15,23,42,0.1);
  --shadow:0 10px 30px rgba(3,7,18,.08), 0 2px 8px rgba(3,7,18,.06);

  --r-xl:28px;
  --r-lg:20px;
  --r-md:14px;
  --r-sm:10px;
  --pad:clamp(16px, 2vw + 8px, 28px);
  --maxw:1200px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
  color:#0b0f1a;
  background:#ffffff;
  line-height:1.6;
}




/* Header / Nav */
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(150%) blur(6px);
  background:rgba(255,255,255,.7);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.nav{display:flex; align-items:center; justify-content:space-between; gap:16px; height:72px}
.brand{display:flex; align-items:center; gap:10px; font-weight:800; letter-spacing:.2px}
.brand .mark{width:28px; height:28px; display:grid; place-items:center; border-radius:10px; background:linear-gradient(135deg,var(--primary),#40e0c2)}
.nav ul{display:flex; gap:26px; list-style:none; margin:0; padding:0}
.nav a{color:#1f2937; text-decoration:none; font-weight:600}
.nav a:hover{color:var(--primary-900)}
.cta{display:flex; gap:12px}
.btn{appearance:none; border:none; cursor:pointer; padding:12px 18px; font-weight:700; border-radius:14px; transition:transform .06s ease, box-shadow .2s ease;}
.btn:active{transform:translateY(1px)}
.btn-outline{background:#fff; border:1px solid var(--ring)}
.btn-primary{color:#083a30; background:linear-gradient(180deg,var(--primary), #18b58a); box-shadow:0 10px 20px rgba(24,181,138,.25)}

/* Hero */
.hero{position:relative; overflow:hidden; background:linear-gradient(180deg, #e9fbf5 0%, #f7fffb 100%);}
.hero-wrap{display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center; padding:64px 0}
.kicker{display:inline-flex; gap:8px; align-items:center; background:#fff; color:#0a3d31; padding:8px 12px; border-radius:999px; font-size:12px; font-weight:800; border:1px solid var(--ring)}
.kicker svg{width:14px; height:14px}
.hero h1{font-size:clamp(30px, 3.5vw + 8px, 56px); line-height:1.05; margin:14px 0 10px; letter-spacing:-.02em}
.hero p{max-width:48ch; color:#334155; font-size:clamp(14px, 1vw + 12px, 18px)}
.hero-actions{display:flex; gap:12px; margin-top:18px}
.pill{display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; font-weight:700; border:1px solid var(--ring); background:#fff}

/* Device mock */
.mock{position:relative; height:520px; display:flex; align-items:center; justify-content:center;}
.phone{width:min(360px, 90%); height:500px; background:#0c1327; border-radius:34px; box-shadow:var(--shadow); border:10px solid black; position:relative; overflow:hidden;}
.screen{position:absolute; inset:0; padding:18px; color:#e2e8f0; font-size:14px}
.bubble{position:absolute; right:-10px; top:60px; transform:rotate(-8deg); width:220px; background:#fff; color:#0f172a; border-radius:18px; box-shadow:var(--shadow); padding:14px}
.bubble small{display:block; color:#64748b}

/* Wave accent */
.hero-wave{position:absolute; left:0; right:0; bottom:-1px; height:60px; background:radial-gradient(120% 80px at 20% 0%, rgba(33,194,150,.25), rgba(33,194,150,0) 70%)}

/* Trust row */
.trust{display:flex; gap:26px; flex-wrap:wrap; align-items:center; justify-content:space-between; padding:22px 0; color:#64748b; font-weight:600}
.trust span{opacity:.7}

/* Why choose us */
.section{padding:72px 0}
/* FIXED: corrected invalid hex (#eafe f7 -> #eafef7) */
.eyebrow{display:inline-flex; gap:8px; align-items:center; text-transform:uppercase; letter-spacing:.12em; color:#0b8067; font-weight:800; font-size:12px; background:#eafef7;}
.section h2{font-size:clamp(26px, 2.7vw + 8px, 40px); letter-spacing:-.02em; text-align:center; margin:10px 0}
.lead{color:#475569; text-align:center; max-width:68ch; margin:0 auto 28px}
.features{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.feature{background:var(--card); border:1px solid var(--ring); border-radius:var(--r-lg); padding:18px; box-shadow:var(--shadow)}
.feature h3{margin:10px 0 6px; font-size:18px}
.feature p{margin:0; color:#475569; font-size:14px}
.icon{width:38px; height:38px; border-radius:10px; display:grid; place-items:center; font-weight:800; color:white}
.i-blue{background:var(--accent-blue)}
.i-orange{background:var(--accent-orange)}
.i-green{background:var(--primary)}
.i-violet{background:var(--accent-violet)}

/* Courses strip */
.courses{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:22px}
.course{background:var(--card-2); border:1px solid var(--ring); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow)}
.course img{display:block; width:100%; height:160px; object-fit:cover}
.course .meta{padding:14px}
.tag{display:inline-block; padding:6px 10px; border-radius:999px; font-size:12px; font-weight:700; background:#ecfeff; color:#02687a; border:1px solid #a5f3fc}

/* Footer */
footer{padding:60px 0; background:#ffffff; color:#cbd5e1}
footer .brand{color:#e2e8f0}
.footgrid{display:grid; grid-template-columns:2fr 1fr 1fr; gap:28px; margin-top:18px}
footer a{color:#cbd5e1; text-decoration:none}

/* Responsive */
@media (max-width:1000px){
  .hero-wrap{grid-template-columns:1fr; gap:20px}
  .mock{height:460px}
  .features{grid-template-columns:repeat(2,1fr)}
  .courses{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .nav ul{display:none}
  .features{grid-template-columns:1fr}
  .courses{grid-template-columns:1fr}
}

/* A11y / motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important; transition:none!important}
}
.btn:focus-visible, a:focus-visible{outline:3px solid var(--accent-blue); outline-offset:3px; border-radius:12px}


/* RSM Academy – Hero v1 (compat) */
.rsm-hero{position:relative; overflow:hidden; background:linear-gradient(180deg,#e7fbf3 0%,#f5fffb 100%);}
.rsm-hero .rsm-wrap{max-width:1200px; margin:0 auto; padding:64px 24px; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center}

/* Left column */
.rsm-hero .kicker{display:inline-flex; align-items:center; gap:8px; background:#ffffff; color:#0a3d31; border:1px solid rgba(15,23,42,0.08); border-radius:999px; padding:8px 12px; font:700 12px/1 Inter,Arial,Helvetica,sans-serif}
.rsm-hero h1{font:800 48px/1.1 Inter,Arial,Helvetica,sans-serif; color:#083a30; margin:16px 0 10px}
.rsm-hero p.lead{max-width:56ch; color:#334155; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif; margin:0 0 16px}

/* Pills */
.rsm-hero .pills{display:flex; flex-wrap:wrap; gap:10px; margin:10px 0 18px}
.rsm-hero .pill{display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; background:#fff; border:1px solid rgba(15,23,42,0.1); font:700 13px/1 Inter,Arial,Helvetica,sans-serif; color:#0f172a}
.rsm-hero .pill i{width:18px; height:18px; display:inline-grid; place-items:center; border-radius:6px; background:#21c296; color:#083a30; font-style:normal; font-weight:900}

/* Actions */
.rsm-hero .actions{display:flex; gap:12px; align-items:center; margin-top:6px}
.rsm-hero .btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; border-radius:14px; font:800 14px/1 Inter,Arial,Helvetica,sans-serif; text-decoration:none; border:1px solid transparent}
.rsm-hero .btn-primary{background:linear-gradient(180deg,#21c296,#18b58a); color:#083a30; border-color:rgba(24,181,138,.35); box-shadow:0 10px 20px rgba(24,181,138,.25)}
.rsm-hero .btn-secondary{background:#ffffff; color:#0f172a; border-color:rgba(15,23,42,0.1)}
.rsm-hero .btn:hover{filter:brightness(.98)}

/* Restore gradient hero background */
.rsm-hero {
  background:linear-gradient(180deg, #e9fbf5 0%, #f7fffb 100%) !important;
  position:relative;
  overflow:hidden;
}

.rsm-hero:before {
  content:"";
  position:absolute;
  right:-80px;
  top:-80px;
  width:440px;
  height:440px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(33,194,150,.25), rgba(33,194,150,0) 70%);
}


/* Right-side visual (image replaces old device mock) */
.rsm-hero .mock{
  position:relative;
  height:auto;
  display:flex;
  justify-content:center;   /* center align */
  align-items:center;
  padding:10px 0;
}

.rsm-hero .hero-visual{
  display:block;
  max-width:100%;
  height:auto;
  max-height:560px;         /* a bit larger for visual focus (Size B) */
  border-radius:22px;       /* medium corners */
  box-shadow:0 12px 28px rgba(3,7,18,.14), 0 3px 10px rgba(3,7,18,.10); /* medium soft shadow */
}

/* mobile tweaks */
@media (max-width:1000px){ .rsm-hero .hero-visual{ max-height:480px; border-radius:20px; } }
@media (max-width:640px){  .rsm-hero .hero-visual{ max-height:360px; border-radius:16px; } }

/* === Scrolling banner under hero (no JS) === */
.rsm-marquee{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%);
  border-top:1px solid rgba(15,23,42,.06);
  border-bottom:1px solid rgba(15,23,42,.06);
  padding:10px 0;
}
.rsm-marquee-track{
  display:flex;
  gap:14px;
  width:max-content;
  animation:rsm-marquee-move 30s linear infinite;
  will-change:transform;
  padding:6px 0;
}
.rsm-marquee .pill{
  display:inline-flex; align-items:center; white-space:nowrap;
  padding:10px 14px; border-radius:999px; text-decoration:none;
  font:700 14px/1.1 Inter, Arial, Helvetica, sans-serif;
  color:#0f172a; background:#ffffff; border:1px solid rgba(15,23,42,.10);
  box-shadow:0 6px 16px rgba(3,7,18,.06);
}
.rsm-marquee .pill:hover{ filter:brightness(.98); }

/* Seamless scroll (duplicate items in HTML) */
@keyframes rsm-marquee-move{
  from{ transform:translateX(0); }
  to{   transform:translateX(-50%); }
}

/* Pause on hover/focus for accessibility */
.rsm-marquee:hover .rsm-marquee-track,
.rsm-marquee:focus-within .rsm-marquee-track{
  animation-play-state:paused;
}

/* Respect reduced motion */
@media (prefers-reduced-motion:reduce){
  .rsm-marquee-track{ animation:none; }
}

/* Responsive spacing */
@media (max-width:640px){
  .rsm-marquee .pill{ padding:8px 12px; font-weight:700; font-size:13px; }
}

/* ===== Programs section (matches hero styling) ===== */
.rsm-programs{ padding:48px 0 56px; background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%); border-top:1px solid rgba(15,23,42,.06); }
.rsm-programs .rsm-wrap{ max-width:1200px; margin:0 auto; padding:0 24px; }
.rsm-programs h2{ margin:0 0 14px; font:800 36px/1.15 Inter,Arial,Helvetica,sans-serif; letter-spacing:-.02em; color:#0b0f1a; }

/* chips row */
.rsm-chips{ display:flex; flex-wrap:wrap; gap:10px; margin:8px 0 22px; }
.rsm-chips .chip{
  display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px;
  font:700 14px/1.1 Inter,Arial,Helvetica,sans-serif; text-decoration:none;
  color:#0f172a; background:#fff; border:1px solid rgba(15,23,42,.10);
  box-shadow:0 8px 18px rgba(3,7,18,.06);
}
.rsm-chips .chip:hover{ filter:brightness(.98); }

/* card grid */
.rsm-card-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.rsm-card{
  position:relative; display:flex; flex-direction:column; gap:10px;
  padding:16px; border-radius:20px; text-decoration:none; background:#ffffff;
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 12px 28px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.rsm-card:hover{ transform:translateY(-2px); box-shadow:0 16px 34px rgba(3,7,18,.12), 0 6px 16px rgba(3,7,18,.08); border-color:rgba(15,23,42,.16); }

.card-icon{
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  color:#fff; font:900 14px/1 Inter,Arial,Helvetica,sans-serif;
}
.card-body h3{ margin:2px 0 6px; font:800 18px/1.25 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.card-body p{ margin:0; color:#475569; font:500 14px/1.6 Inter,Arial,Helvetica,sans-serif; }
.card-cta{ margin-top:6px; font:800 13px/1 Inter,Arial,Helvetica,sans-serif; color:#07725a; }

/* responsive */
@media (max-width:1000px){ .rsm-card-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .rsm-card-grid{ grid-template-columns:1fr; } .rsm-programs h2{ font-size:28px; } }

/* accessibility */
@media (prefers-reduced-motion:reduce){
  .rsm-card{ transition:none; }
}
/* Thumbnail style for app logos */
.rsm-card .card-icon.thumb{
  width:44px; height:44px; border-radius:12px;
  background:#ffffff; border:1px solid rgba(15,23,42,.10);
  display:grid; place-items:center; box-shadow:0 6px 16px rgba(3,7,18,.06);
}
.rsm-card .card-icon.thumb img{
  display:block; width:auto; height:26px; /* consistent size */
}

/* Optional: subtle grow on hover */
.rsm-card:hover .card-icon.thumb img{ transform:scale(1.04); transition:transform .15s ease; }

/* If you prefer no white tile behind the logo, use this instead: */
/*
.rsm-card .card-icon.thumb{ background:transparent; border:none; box-shadow:none; }
*/

/* ===== Login / Create Account section ===== */
.rsm-auth{
  padding:48px 0 56px;
  background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%);
  border-top:1px solid rgba(15,23,42,.06);
}
.rsm-auth .rsm-wrap{ max-width:1200px; margin:0 auto; padding:0 24px; }
.rsm-auth h2{ margin:0 0 10px; font:800 36px/1.15 Inter,Arial,Helvetica,sans-serif; letter-spacing:-.02em; color:#0b0f1a; }
.rsm-auth .auth-lead{ margin:0 0 20px; color:#475569; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif; }

.auth-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.auth-card{
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:20px; padding:20px;
  box-shadow:0 12px 28px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
}
.auth-card h3{ margin:8px 0 6px; font:800 20px/1.2 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.auth-text{ margin:0 0 14px; color:#475569; font:500 14px/1.6 Inter,Arial,Helvetica,sans-serif; }
.auth-badge{
  display:inline-block; padding:6px 10px; border-radius:999px; font:800 11px/1 Inter,Arial,Helvetica,sans-serif;
  background:#eafef7; color:#0b8067; border:1px solid #a7f3d0;
}
.auth-badge.alt{ background:#eef2ff; color:#3730a3; border-color:#c7d2fe; }

.auth-actions{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin:8px 0 0; }

/* Buttons (reuse your hero button styles if present) */
.rsm-auth .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 18px; border-radius:14px; font:800 14px/1 Inter,Arial,Helvetica,sans-serif;
  text-decoration:none; border:1px solid transparent; cursor:pointer;
}
.rsm-auth .btn-primary{ background:linear-gradient(180deg,#21c296,#18b58a); color:#083a30; border-color:rgba(24,181,138,.35); box-shadow:0 10px 20px rgba(24,181,138,.25); }
.rsm-auth .btn-secondary{ background:#0b8067; color:#ffffff; border-color:#0b8067; }
.rsm-auth .btn-ghost{ background:#ffffff; color:#0f172a; border:1px solid rgba(15,23,42,.12); }
.rsm-auth .btn-sso{
  background:#ffffff; color:#0f172a; border:1px solid rgba(15,23,42,.12);
  padding:12px 16px; margin-top:10px;
}
.rsm-auth .btn:hover{ filter:brightness(.98); }

.auth-fineprint{
  margin:16px 0 0; color:#65748b; font:500 12px/1.6 Inter,Arial,Helvetica,sans-serif;
}
.auth-fineprint a{ color:#0b8067; text-decoration:none; border-bottom:1px dashed rgba(11,128,103,.4); }

/* Responsive */
@media (max-width:1000px){ .auth-grid{ grid-template-columns:1fr; } .rsm-auth h2{ font-size:30px; } }
@media (max-width:640px){  .rsm-auth h2{ font-size:26px; } }

/* =========================================
   RSM Catalog Skin v3 — Non-destructive polish
   Matches the new hero/home styles
   ========================================= */

/* Page background to match hero vibe */
body .catalog,
body [class*="catalog-page"],
body [class*="catalog_index"]{
  background: linear-gradient(180deg,#f7fffb 0%, #ffffff 100%);
}

/* Container padding (gentle) */
body .catalog .container,
body [class*="catalog"] .container{
  max-width: 1200px;
  margin-left: auto; margin-right: auto;
  padding-left: 24px; padding-right: 24px;
}

/* Title & intro */
body [class*="catalog"] h1,
body [class*="catalog"] h2.page-title{
  font: 800 32px/1.15 Inter, Arial, Helvetica, sans-serif;
  letter-spacing: -.02em; color:#0b0f1a; margin: 10px 0 14px;
}
body [class*="catalog"] .page-subtitle,
body [class*="catalog"] p.lead{
  color:#475569; font:500 16px/1.6 Inter, Arial, Helvetica, sans-serif;
}

/* Search bar & filter controls (cosmetic only) */
body [class*="catalog"] input[type="search"],
body [class*="search"] input,
body .catalog [class*="search-bar"] input{
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  border-radius: 14px;
  height: 46px;
  padding: 0 14px;
  box-shadow: 0 6px 16px rgba(3,7,18,.06);
  font:500 14px/1 Inter, Arial, Helvetica, sans-serif;
  color:#0f172a;
}
body .catalog [class*="filters"] a,
body .catalog [class*="filters"] button,
body .catalog [class*="filter"],
body .catalog [class*="facet"]{
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: #fff;
  color:#0f172a;
  font-weight:700;
  padding: 8px 12px;
  box-shadow: 0 6px 16px rgba(3,7,18,.06);
}

/* Course cards — purely visual */
body .catalog [class*="card"],
body .catalog [class*="tile"],
body .catalog [class*="listing-card"],
body .catalog [class*="course"] [class*="item"]{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 12px 28px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
body .catalog [class*="card"]:hover,
body .catalog [class*="tile"]:hover,
body .catalog [class*="listing-card"]:hover{
  transform: translateY(-2px);
  box-shadow:0 16px 34px rgba(3,7,18,.12), 0 6px 16px rgba(3,7,18,.08);
  border-color: rgba(15,23,42,.16);
}

/* Thumbnails: consistent crop */
body .catalog [class*="card"] img,
body .catalog [class*="tile"] img{
  width:100%;
  height: 180px;
  object-fit: cover;
  display:block;
}

/* Titles, text */
body .catalog [class*="card"] [class*="title"],
body .catalog [class*="tile"] h3,
body .catalog h3.course-title{
  font: 800 18px/1.25 Inter, Arial, Helvetica, sans-serif;
  color:#0b0f1a;
  margin:10px 14px 6px;
}
body .catalog [class*="card"] p,
body .catalog [class*="tile"] p{
  color:#475569;
  font:500 14px/1.6 Inter, Arial, Helvetica, sans-serif;
  margin:0 14px 12px;
}

/* Tag chips (difficulty, product, format, etc.) */
body .catalog [class*="tag"],
body .catalog [class*="badge"],
body .catalog [class*="label"]{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  background:#ecfeff;
  color:#02687a;
  border:1px solid #a5f3fc;
  font:800 11px/1 Inter, Arial, Helvetica, sans-serif;
  margin: 0 8px 10px 14px;
}

/* Primary CTA buttons on cards */
body .catalog a[class*="enroll"],
body .catalog a[class*="view"],
body .catalog [class*="btn-primary"],
body .catalog .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 16px;
  border-radius:14px; text-decoration:none;
  font:800 14px/1 Inter, Arial, Helvetica, sans-serif;
  border:1px solid rgba(24,181,138,.35);
  background: linear-gradient(180deg,#21c296,#18b58a);
  color:#083a30;
  box-shadow:0 10px 20px rgba(24,181,138,.25);
}
body .catalog a[class*="enroll"]:hover,
body .catalog [class*="btn-primary"]:hover{ filter:brightness(.98); }

/* Secondary buttons */
body .catalog a[class*="secondary"],
body .catalog .btn-secondary{
  background:#fff; color:#0f172a;
  border:1px solid rgba(15,23,42,.12);
  box-shadow:0 6px 16px rgba(3,7,18,.06);
}

/* Pagination polish */
body .pagination a, body .pagination span{
  min-width:38px; height:38px; display:grid; place-items:center;
  background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:10px;
  font-weight:700; color:#0f172a; text-decoration:none;
  box-shadow:0 6px 16px rgba(3,7,18,.06);
}
body .pagination .active, body .pagination a:hover{
  border-color:#0b8067; color:#0b8067;
}

/* Little cleanups */
body .catalog li{ list-style:none; }
body .catalog [class*="meta"] i, body .catalog [class*="icon"]{ color:inherit; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  body .catalog [class*="card"], body .catalog [class*="tile"]{ transition:none; }
}


/* ===== Catalog Hero (matches home hero) ===== */
.rsm-cat-hero{
  position:relative; overflow:hidden;
  background:linear-gradient(180deg, #e9fbf5 0%, #f7fffb 100%);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.rsm-cat-wrap{
  max-width:1200px; margin:0 auto; padding:56px 24px;
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
}
.rsm-cat-left .kicker{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; color:#0a3d31; border:1px solid rgba(15,23,42,.08);
  border-radius:999px; padding:8px 12px; font:800 12px/1 Inter,Arial,Helvetica,sans-serif;
}
.rsm-cat-left h1{
  font:800 40px/1.12 Inter,Arial,Helvetica,sans-serif; letter-spacing:-.02em; color:#083a30;
  margin:14px 0 10px;
}
.rsm-cat-left .lead{
  max-width:60ch; color:#334155; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif; margin:0 0 16px;
}

/* Search bar in hero */
.rsm-cat-search{ display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 14px; }
.rsm-cat-search input[type="search"]{
  flex:1 1 340px; height:46px; padding:0 14px;
  border-radius:14px; border:1px solid rgba(15,23,42,.12); background:#fff;
  box-shadow:0 6px 16px rgba(3,7,18,.06); font:500 14px/1 Inter,Arial,Helvetica,sans-serif; color:#0f172a;
}
.rsm-cat-search .btn.btn-primary{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  height:46px; padding:0 18px; border-radius:14px; text-decoration:none; border:1px solid rgba(24,181,138,.35);
  background:linear-gradient(180deg,#21c296,#18b58a); color:#083a30; font:800 14px/1 Inter,Arial,Helvetica,sans-serif;
  box-shadow:0 10px 20px rgba(24,181,138,.25);
}
.rsm-cat-search .btn.btn-primary:hover{ filter:brightness(.98); }

/* Chips row */
.rsm-cat-chips{ display:flex; flex-wrap:wrap; gap:10px; margin:8px 0 0; }
.rsm-cat-chips .chip{
  display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px;
  font:700 14px/1.1 Inter,Arial,Helvetica,sans-serif; text-decoration:none;
  color:#0f172a; background:#fff; border:1px solid rgba(15,23,42,.10);
  box-shadow:0 8px 18px rgba(3,7,18,.06);
}
.rsm-cat-chips .chip:hover{ filter:brightness(.98); }

/* Right image (simple banner) */
.rsm-cat-right{ display:flex; justify-content:center; }
.rsm-cat-right .hero-visual{
  display:block; max-width:100%; height:auto; max-height:520px;
  border-radius:22px; box-shadow:0 12px 28px rgba(3,7,18,.14), 0 3px 10px rgba(3,7,18,.10);
}

/* Responsive */
@media (max-width:1000px){
  .rsm-cat-wrap{ grid-template-columns:1fr; gap:22px; padding:44px 20px; }
  .rsm-cat-left h1{ font-size:34px; }
  .rsm-cat-right .hero-visual{ max-height:420px; border-radius:20px; }
}
@media (max-width:640px){
  .rsm-cat-left h1{ font-size:28px; }
  .rsm-cat-right .hero-visual{ max-height:320px; border-radius:16px; }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .rsm-cat-search .btn, .rsm-cat-chips .chip{ transition:none; }
}

/* ===== Training Services tiles ===== */
.rsm-services{
  padding:48px 0 56px;
  background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%);
  border-top:1px solid rgba(15,23,42,.06);
}
.rsm-services .rsm-wrap{ max-width:1200px; margin:0 auto; padding:0 24px; }
.rsm-services h2{
  margin:0 0 8px;
  font:800 32px/1.15 Inter,Arial,Helvetica,sans-serif; letter-spacing:-.02em; color:#0b0f1a;
}
.rsm-services .services-lead{
  margin:0 0 22px; color:#475569; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif;
}

/* Grid */
.rsm-services-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
@media (max-width:1000px){ .rsm-services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){  .rsm-services-grid{ grid-template-columns:1fr; } }

/* Card */
.svc-card{
  position:relative; display:flex; flex-direction:column; gap:10px;
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:20px; padding:18px;
  text-decoration:none;
  box-shadow:0 12px 28px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.svc-card:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 34px rgba(3,7,18,.12), 0 6px 16px rgba(3,7,18,.08);
  border-color:rgba(15,23,42,.16);
}
.svc-icon{
  width:44px; height:44px; border-radius:12px;
  display:grid; place-items:center; font-size:20px; font-weight:900; color:#083a30;
  background:#eafef7; border:1px solid #a7f3d0; box-shadow:0 6px 16px rgba(3,7,18,.06);
}
.svc-card h3{ margin:2px 0 6px; font:800 18px/1.25 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.svc-card p{ margin:0; color:#475569; font:500 14px/1.6 Inter,Arial,Helvetica,sans-serif; }
.svc-cta{ margin-top:8px; font:800 13px/1 Inter,Arial,Helvetica,sans-serif; color:#07725a; }

/* ===============================
   Workshops Hero (RSM Theme)
   =============================== */

.rsm-workshops-hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, #e9fbf5 0%, #f7fffb 100%);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.rsm-workshops-hero .rsm-hero-wrap{
  display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:40px;
  max-width:1200px; margin:0 auto; padding:64px 24px;
}

.rsm-workshops-hero .kicker{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; color:#0a3d31; border:1px solid rgba(15,23,42,.08);
  border-radius:999px; padding:8px 12px; font:800 12px/1 Inter,Arial,Helvetica,sans-serif;
}

.rsm-workshops-hero h1{
  font:800 40px/1.15 Inter,Arial,Helvetica,sans-serif;
  letter-spacing:-.02em; color:#083a30;
  margin:14px 0 10px;
}

.rsm-workshops-hero .lead{
  max-width:62ch; color:#334155; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif;
  margin:0 0 20px;
}

/* Buttons */
.rsm-workshops-hero .rsm-hero-actions{ display:flex; gap:12px; flex-wrap:wrap; }

.rsm-workshops-hero .btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 18px; border-radius:14px; text-decoration:none; font:800 14px/1 Inter,Arial,Helvetica,sans-serif;
  border:1px solid transparent; cursor:pointer;
}
.rsm-workshops-hero .btn-primary{
  background:linear-gradient(180deg,#21c296,#18b58a);
  color:#083a30; border-color:rgba(24,181,138,.35);
  box-shadow:0 10px 20px rgba(24,181,138,.25);
}
.rsm-workshops-hero .btn-primary:hover{ filter:brightness(.98); }
.rsm-workshops-hero .btn-secondary{
  background:#fff; color:#0f172a;
  border:1px solid rgba(15,23,42,.12);
  box-shadow:0 6px 16px rgba(3,7,18,.06);
}

/* Right Image */
.rsm-workshops-hero .rsm-hero-right{ display:flex; justify-content:center; }
.rsm-workshops-hero .hero-img{
  max-width:100%; height:auto; max-height:500px;
  border-radius:22px;
  box-shadow:0 12px 28px rgba(3,7,18,.14), 0 3px 10px rgba(3,7,18,.10);
}

/* Responsive */
@media (max-width:1000px){
  .rsm-workshops-hero .rsm-hero-wrap{ grid-template-columns:1fr; gap:24px; padding:48px 20px; }
  .rsm-workshops-hero h1{ font-size:34px; }
}
@media (max-width:640px){
  .rsm-workshops-hero h1{ font-size:28px; }
  .rsm-workshops-hero .hero-img{ max-height:320px; border-radius:16px; }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .rsm-workshops-hero *{ transition:none!important; animation:none!important; }
}


/* =====================================================
   Accent Section Header + Featured Workshops
   (Matches the violet/blue Upcoming Workshops hero)
   ===================================================== */

/* Shared wrapper */
.rsm-wrap { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* Accent header */
.rsm-accent-header {
  position: relative;
  padding: 32px 0 8px;
  background: radial-gradient(circle at 20% -40%, rgba(123,97,255,0.12), transparent 60%),
              linear-gradient(180deg, #faf9ff 0%, #ffffff 100%);
  border-top: 1px solid rgba(15,23,42,0.06);
  border-bottom: 1px solid rgba(15,23,42,0.06);
}
.rsm-accent-header .head { text-align: left; }
.rsm-accent-header .kicker{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; color:#5b45d4; border:1px solid rgba(91,69,212,0.18);
  border-radius:999px; padding:8px 12px; font:800 12px/1 Inter,Arial,Helvetica,sans-serif;
  text-transform:uppercase; letter-spacing:.08em;
  box-shadow:0 2px 8px rgba(91,69,212,.06);
}
.rsm-accent-header h2{
  margin:12px 0 8px; font:800 32px/1.12 Inter,Arial,Helvetica,sans-serif;
  letter-spacing:-.02em; color:#2b2077; text-shadow:0 1px 3px rgba(123,97,255,.12);
}
.rsm-accent-header .lead{
  margin:0; color:#403e57; font:500 16px/1.65 Inter,Arial,Helvetica,sans-serif; max-width:70ch;
}

/* Header chips */
.rsm-accent-header .chips{
  display:flex; flex-wrap:wrap; gap:10px; margin:12px 0 16px;
}
.rsm-accent-header .chip{
  display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px;
  font:700 14px/1.1 Inter,Arial,Helvetica,sans-serif; text-decoration:none;
  color:#2a296b; background:#fff; border:1px solid rgba(91,69,212,0.15);
  box-shadow:0 8px 18px rgba(123,97,255,0.08); transition:.25s ease;
}
.rsm-accent-header .chip:hover{ background:#edeaff; border-color:rgba(91,69,212,0.25); transform:translateY(-2px); }

/* Featured cards */
.rsm-featured{ padding:20px 0 36px; background:#fff; }
.rsm-grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:1000px){ .rsm-grid-3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .rsm-grid-3{ grid-template-columns:1fr; } }

.fw-card{
  display:flex; flex-direction:column; justify-content:space-between; gap:10px;
  background:#ffffff; border:1px solid rgba(15,23,42,.10); border-radius:20px; padding:18px;
  text-decoration:none;
  box-shadow:0 14px 32px rgba(3,7,18,.10), 0 4px 12px rgba(3,7,18,.06);
  transition: transform .18s ease, box-shadow .22s ease, border-color .22s ease;
}
.fw-card:hover{ transform:translateY(-2px); border-color:rgba(91,69,212,.25); box-shadow:0 18px 40px rgba(91,69,212,.15), 0 6px 16px rgba(3,7,18,.08); }

.fw-top .pill{
  display:inline-block; padding:6px 10px; border-radius:999px;
  background:#f0edff; color:#3b2ea1; border:1px solid rgba(91,69,212,.25);
  font:800 11px/1 Inter,Arial,Helvetica,sans-serif;
}
.fw-card h3{ margin:8px 0 6px; font:800 18px/1.25 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.fw-card p{ margin:0; color:#475569; font:500 14px/1.6 Inter,Arial,Helvetica,sans-serif; }

.fw-meta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:10px; color:#667085; font:700 12px/1.2 Inter,Arial,Helvetica,sans-serif; }

.fw-cta{
  margin-top:10px; font:800 13px/1 Inter,Arial,Helvetica,sans-serif; color:#5b45d4;
}

/* Centered CTA row */
.rsm-featured .centered{ text-align:center; margin-top:18px; }
.rsm-featured .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 18px; border-radius:14px; text-decoration:none; font:800 14px/1 Inter,Arial,Helvetica,sans-serif;
  border:1px solid transparent; cursor:pointer;
}
.rsm-featured .btn.btn-primary{
  background:linear-gradient(180deg,#7b61ff,#5d46dc); color:#fff; border-color:rgba(123,97,255,.35);
  box-shadow:0 8px 22px rgba(123,97,255,.35);
}
.rsm-featured .btn.btn-primary:hover{ filter:brightness(1.05); transform:translateY(-1px); }

/* Nice, subtle section separators */
.rsm-featured::before{
  content:""; display:block; height:1px; background:linear-gradient(90deg, rgba(123,97,255,.12), rgba(33,194,150,.12));
  margin:0 24px 18px; border-radius:2px;
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .fw-card, .rsm-accent-header .chip, .rsm-featured .btn { transition:none!important; }
}

/* ===============================
   Upcoming Workshops Hero (Violet/Blue)
   Safe append – does not affect other heroes
   =============================== */

.rsm-upcoming-hero{
  position:relative; overflow:hidden;
  background: radial-gradient(circle at 60% -20%, rgba(123,97,255,0.18), transparent 65%),
              linear-gradient(180deg, #f5f3ff 0%, #fafaff 100%);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.rsm-upcoming-hero .rsm-hero-wrap{
  max-width:1200px; margin:0 auto; padding:64px 24px;
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
}
.rsm-upcoming-hero .kicker{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; color:#5b45d4; border:1px solid rgba(91,69,212,.18);
  border-radius:999px; padding:8px 12px; font:800 12px/1 Inter,Arial,Helvetica,sans-serif;
  text-transform:uppercase; letter-spacing:.08em; box-shadow:0 2px 8px rgba(91,69,212,.06);
}
.rsm-upcoming-hero h1{
  font:800 40px/1.12 Inter,Arial,Helvetica,sans-serif; letter-spacing:-.02em; color:#2b2077;
  margin:14px 0 12px; text-shadow:0 2px 6px rgba(123,97,255,.12);
}
.rsm-upcoming-hero .lead{
  max-width:62ch; color:#403e57; font:500 16px/1.65 Inter,Arial,Helvetica,sans-serif; margin:0 0 18px;
}
.rsm-upcoming-hero .rsm-hero-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:6px; }
.rsm-upcoming-hero .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 18px; border-radius:14px; text-decoration:none; font:800 14px/1 Inter,Arial,Helvetica,sans-serif;
  border:1px solid transparent; cursor:pointer; transition:.25s ease;
}
.rsm-upcoming-hero .btn.btn-primary{
  background:linear-gradient(180deg,#7b61ff,#5d46dc); color:#fff; border-color:rgba(123,97,255,.35);
  box-shadow:0 8px 22px rgba(123,97,255,.35);
}
.rsm-upcoming-hero .btn.btn-primary:hover{ filter:brightness(1.05); transform:translateY(-1px); }
.rsm-upcoming-hero .btn.btn-secondary{
  background:#fff; color:#3b2ea1; border:1px solid rgba(91,69,212,.2); box-shadow:0 6px 16px rgba(91,69,212,.08);
}
.rsm-upcoming-hero .btn.btn-secondary:hover{ background:#f0edff; transform:translateY(-1px); }

.rsm-upcoming-hero .rsm-hero-right{ display:flex; justify-content:center; }
.rsm-upcoming-hero .hero-img{
  display:block; max-width:100%; height:auto; max-height:520px; border-radius:26px;
  box-shadow:0 20px 44px rgba(3,7,18,.12), 0 4px 12px rgba(3,7,18,.08);
  transition: transform .35s ease, box-shadow .35s ease;
}
.rsm-upcoming-hero .hero-img:hover{ transform:scale(1.03); box-shadow:0 24px 56px rgba(91,69,212,.18); }

/* Responsive */
@media (max-width:1000px){
  .rsm-upcoming-hero .rsm-hero-wrap{ grid-template-columns:1fr; gap:22px; padding:48px 20px; }
  .rsm-upcoming-hero h1{ font-size:34px; }
  .rsm-upcoming-hero .hero-img{ max-height:420px; border-radius:20px; }
}
@media (max-width:640px){
  .rsm-upcoming-hero h1{ font-size:28px; }
  .rsm-upcoming-hero .hero-img{ max-height:320px; border-radius:16px; }
}
/* Prevent theme wrappers from squashing our grid spacing */
.rsm-upcoming-hero .rsm-hero-wrap,
.rsm-accent-header .rsm-wrap,
.rsm-featured .rsm-wrap { width:100%; }

/* Ensure images never overflow containers */
img.hero-img { max-width:100%; height:auto; }

/* ===============================
   End-User Training page styles
   =============================== */

/* Hero (green, matching your brand) */
.rsm-training-hero{
  position:relative; overflow:hidden;
  background:linear-gradient(180deg,#e9fbf5 0%, #f7fffb 100%);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.training-hero-wrap{
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
  max-width:1200px; margin:0 auto; padding:64px 24px;
}
.rsm-training-hero .kicker{
  display:inline-flex; gap:8px; align-items:center;
  background:#fff; color:#0a3d31; border:1px solid rgba(15,23,42,.08);
  border-radius:999px; padding:8px 12px; font:800 12px/1 Inter,Arial,Helvetica,sans-serif;
}
.rsm-training-hero h1{
  font:800 40px/1.12 Inter,Arial,Helvetica,sans-serif; letter-spacing:-.02em; color:#083a30;
  margin:14px 0 10px;
}
.rsm-training-hero .lead{
  max-width:62ch; color:#334155; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif; margin:0 0 18px;
}
.rsm-training-hero .actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:6px; }

.rsm-training-hero .chips{ display:flex; flex-wrap:wrap; gap:10px; margin:12px 0 0; }
.rsm-training-hero .chip{
  display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px;
  font:700 14px/1.1 Inter,Arial,Helvetica,sans-serif;
  color:#0f172a; background:#fff; border:1px solid rgba(15,23,42,.10);
  box-shadow:0 8px 18px rgba(3,7,18,.06);
}
.rsm-training-hero .right{ display:flex; justify-content:center; }
.rsm-training-hero .hero-visual{
  display:block; max-width:100%; height:auto; max-height:520px;
  border-radius:22px; box-shadow:0 12px 28px rgba(3,7,18,.14), 0 3px 10px rgba(3,7,18,.10);
}

/* What we deliver */
.rsm-training-block{ padding:48px 0 8px; background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%); border-top:1px solid rgba(15,23,42,.06); }
.rsm-training-block .head h2{
  margin:0 0 8px; font:800 32px/1.15 Inter,Arial,Helvetica,sans-serif; letter-spacing:-.02em; color:#0b0f1a;
}
.rsm-training-block .head .sub{
  margin:0 0 18px; color:#475569; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif;
}
.rsm-training-block .grid-3{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.t-card{
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:20px; padding:18px;
  box-shadow:0 12px 28px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.t-card:hover{ transform:translateY(-2px); box-shadow:0 16px 34px rgba(3,7,18,.12), 0 6px 16px rgba(3,7,18,.08); border-color:rgba(15,23,42,.16); }
.t-card .thumb{
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:#eafef7; color:#0b8067; border:1px solid #a7f3d0; box-shadow:0 6px 16px rgba(3,7,18,.06);
  font-weight:900; font-size:18px;
}
.t-card h3{ margin:8px 0 6px; font:800 18px/1.25 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.t-card p{ margin:0; color:#475569; font:500 14px/1.6 Inter,Arial,Helvetica,sans-serif; }

/* How it works (timeline/steps) */
.rsm-training-flow{ padding:32px 0 8px; background:#fff; }
.rsm-training-flow .head h2{ margin:0 0 10px; font:800 28px/1.2 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.flow{
  counter-reset: step; display:grid; grid-template-columns:repeat(4,1fr); gap:16px; padding:0; margin:0; list-style:none;
}
.flow li{
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:18px; padding:16px;
  box-shadow:0 10px 24px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
}
.flow li h4::before{
  counter-increment: step; content: counter(step);
  display:inline-grid; place-items:center; width:28px; height:28px; margin-right:8px;
  border-radius:999px; background:#eafef7; color:#0b8067; border:1px solid #a7f3d0; font:800 13px/1 Inter,Arial,Helvetica,sans-serif;
}
.flow li h4{ margin:0 0 6px; font:800 16px/1.2 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.flow li p{ margin:0; color:#475569; font:500 14px/1.6 Inter,Arial,Helvetica,sans-serif; }

/* ROI section */
.rsm-training-roi{ padding:28px 0 6px; background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%); }
.rsm-training-roi .head h2{ margin:0 0 12px; font:800 28px/1.2 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.roi-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.roi-card{
  background:#ffffff; border:1px solid rgba(15,23,42,.10); border-radius:18px; padding:16px;
  text-align:center; box-shadow:0 10px 24px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
}
.roi-card strong{ display:block; font:900 22px/1.1 Inter,Arial,Helvetica,sans-serif; color:#07725a; }
.roi-card span{ color:#475569; font:600 13px/1.5 Inter,Arial,Helvetica,sans-serif; }
.roi-note{ margin:8px 0 0; color:#64748b; font:500 12px/1.5 Inter,Arial,Helvetica,sans-serif; }

/* CTA band */
.rsm-training-cta{
  background: radial-gradient(150% 80% at 100% 0%, rgba(33,194,150,.18), transparent 70%),
              linear-gradient(180deg,#e9fbf5 0%, #f7fffb 100%);
  border-top:1px solid rgba(15,23,42,.06); border-bottom:1px solid rgba(15,23,42,.06);
}
.rsm-training-cta .cta-wrap{
  max-width:1200px; margin:0 auto; padding:22px 24px;
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.rsm-training-cta h3{ margin:0; font:800 22px/1.2 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.rsm-training-cta p{ margin:0; color:#475569; }

/* FAQ */
.rsm-training-faq{ padding:28px 0 48px; background:#fff; }
.rsm-training-faq h2{ margin:0 0 12px; font:800 28px/1.2 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; }
.rsm-training-faq details{
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:16px; padding:12px 14px; margin-bottom:10px;
  box-shadow:0 8px 18px rgba(3,7,18,.06);
}
.rsm-training-faq summary{ cursor:pointer; font-weight:800; color:#0b0f1a; }
.rsm-training-faq details p{ margin:8px 0 0; color:#475569; }

/* Responsive */
@media (max-width:1000px){
  .training-hero-wrap{ grid-template-columns:1fr; gap:22px; padding:48px 20px; }
  .rsm-training-hero h1{ font-size:34px; }
  .rsm-training-block .grid-3{ grid-template-columns:repeat(2,1fr); }
  .flow{ grid-template-columns:repeat(2,1fr); }
  .roi-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .rsm-training-hero h1{ font-size:28px; }
  .rsm-training-hero .hero-visual{ max-height:360px; border-radius:16px; }
  .rsm-training-block .grid-3{ grid-template-columns:1fr; }
  .flow{ grid-template-columns:1fr; }
  .roi-grid{ grid-template-columns:1fr; }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .t-card, .flow li, .rsm-training-cta .btn { transition:none!important; }
}

/* =====================================================
   RSM ILT Services – Scoped Styles (append-only)
   Matches green hero + modern cards
   ===================================================== */

/* ---------- Hero ---------- */
.rsm-ilt-hero{
  position:relative; overflow:hidden;
  background:linear-gradient(180deg,#e9fbf5 0%, #f7fffb 100%);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.rsm-ilt-hero .rsm-ilt-hero-wrap{
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
  max-width:1200px; margin:0 auto; padding:64px 24px;
}
.rsm-ilt-hero .kicker{
  display:inline-flex; gap:8px; align-items:center;
  background:#fff; color:#0a3d31; border:1px solid rgba(15,23,42,.08);
  border-radius:999px; padding:8px 12px; font:800 12px/1 Inter,system-ui,sans-serif;
  text-transform:uppercase; letter-spacing:.08em;
}
.rsm-ilt-hero h1{
  font:800 40px/1.12 Inter,system-ui,sans-serif; letter-spacing:-.02em; color:#083a30;
  margin:14px 0 10px;
}
.rsm-ilt-hero .lead{
  max-width:62ch; color:#334155; font:500 16px/1.6 Inter,system-ui,sans-serif; margin:0 0 18px;
}
.rsm-ilt-hero .actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:6px; }

.rsm-ilt-hero .chips{ display:flex; flex-wrap:wrap; gap:10px; margin:12px 0 0; }
.rsm-ilt-hero .chip{
  display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px;
  font:700 14px/1.1 Inter,system-ui,sans-serif; color:#0f172a; background:#fff;
  border:1px solid rgba(15,23,42,.10); box-shadow:0 8px 18px rgba(3,7,18,.06);
}

.rsm-ilt-hero .right{ display:flex; justify-content:center; }
.rsm-ilt-hero .hero-visual{
  display:block; max-width:100%; height:auto; max-height:520px;
  border-radius:22px; box-shadow:0 12px 28px rgba(3,7,18,.14), 0 3px 10px rgba(3,7,18,.10);
}

/* ---------- Overview (text + image) ---------- */
.rsm-ilt-overview{
  padding:48px 0 8px; background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%);
  border-top:1px solid rgba(15,23,42,.06);
}
.rsm-ilt-overview .head h2{
  margin:0 0 8px; font:800 32px/1.15 Inter,system-ui,sans-serif; letter-spacing:-.02em; color:#0b0f1a;
}
.rsm-ilt-overview .head .sub{
  margin:0 0 20px; color:#475569; font:500 16px/1.6 Inter,system-ui,sans-serif;
}
.rsm-ilt-overview .grid-2{
  display:grid; grid-template-columns:1.1fr .9fr; gap:24px; align-items:center;
}
.rsm-ilt-overview .text p{ margin:0 0 12px; color:#475569; font:500 15px/1.7 Inter,system-ui,sans-serif; }
.rsm-ilt-overview .overview-img{
  display:block; max-width:100%; height:auto; border-radius:18px;
  box-shadow:0 12px 28px rgba(3,7,18,.10), 0 3px 10px rgba(3,7,18,.06);
}

/* ---------- Benefits (cards) ---------- */
.rsm-ilt-benefits{ padding:28px 0 8px; background:#fff; }
.rsm-ilt-benefits .head h2{
  margin:0 0 12px; font:800 28px/1.2 Inter,system-ui,sans-serif; color:#0b0f1a;
}
.rsm-ilt-benefits .grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.rsm-ilt-benefits .card{
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:20px; padding:18px;
  box-shadow:0 12px 28px rgba(3,7,18,.08),0 3px 10px rgba(3,7,18,.06);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.rsm-ilt-benefits .card:hover{
  transform:translateY(-2px); border-color:rgba(15,23,42,.16);
  box-shadow:0 16px 34px rgba(3,7,18,.12), 0 6px 16px rgba(3,7,18,.08);
}
.rsm-ilt-benefits .thumb{
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:#eafef7; color:#0b8067; border:1px solid #a7f3d0; box-shadow:0 6px 16px rgba(3,7,18,.06);
  font-weight:900; font-size:18px;
}
.rsm-ilt-benefits h3{ margin:8px 0 6px; font:800 18px/1.25 Inter,system-ui,sans-serif; color:#0b0f1a; }
.rsm-ilt-benefits p{ margin:0; color:#475569; font:500 14px/1.6 Inter,system-ui,sans-serif; }

/* ---------- Delivery options ---------- */
.rsm-ilt-delivery{ padding:28px 0 8px; background:#fff; }
.rsm-ilt-delivery .head h2{ margin:0 0 8px; font:800 28px/1.2 Inter,system-ui,sans-serif; color:#0b0f1a; }
.rsm-ilt-delivery .head .sub{ margin:0 0 16px; color:#475569; }
.rsm-ilt-delivery .grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.rsm-ilt-delivery .d-card{
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:18px; padding:18px;
  box-shadow:0 10px 24px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
}
.rsm-ilt-delivery .d-card h3{ margin:0 0 6px; font:800 18px/1.25 Inter,system-ui,sans-serif; color:#0b0f1a; }
.rsm-ilt-delivery .d-card p{ margin:0; color:#475569; }

/* ---------- CTA band ---------- */
.rsm-ilt-cta{
  background: radial-gradient(150% 80% at 100% 0%, rgba(33,194,150,.16), transparent 70%),
              linear-gradient(180deg,#e9fbf5 0%, #f7fffb 100%);
  border-top:1px solid rgba(15,23,42,.06); border-bottom:1px solid rgba(15,23,42,.06);
}
.rsm-ilt-cta .cta-wrap{
  max-width:1200px; margin:0 auto; padding:22px 24px;
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.rsm-ilt-cta h3{ margin:0; font:800 22px/1.2 Inter,system-ui,sans-serif; color:#0b0f1a; }
.rsm-ilt-cta p{ margin:0; color:#475569; }

/* ---------- FAQ (reuses your style language) ---------- */
.rsm-ilt-faq{ padding:28px 0 48px; background:#fff; }
.rsm-ilt-faq h2{ margin:0 0 12px; font:800 28px/1.2 Inter,system-ui,sans-serif; color:#0b0f1a; }
.rsm-ilt-faq details{
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:16px; padding:12px 14px; margin-bottom:10px;
  box-shadow:0 8px 18px rgba(3,7,18,.06);
}
.rsm-ilt-faq summary{ cursor:pointer; font-weight:800; color:#0b0f1a; }
.rsm-ilt-faq details p{ margin:8px 0 0; color:#475569; }

/* ---------- Responsive ---------- */
@media (max-width:1000px){
  .rsm-ilt-hero .rsm-ilt-hero-wrap{ grid-template-columns:1fr; gap:22px; padding:48px 20px; }
  .rsm-ilt-hero h1{ font-size:34px; }
  .rsm-ilt-overview .grid-2{ grid-template-columns:1fr; }
  .rsm-ilt-benefits .grid-3,
  .rsm-ilt-delivery .grid-3{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .rsm-ilt-hero h1{ font-size:28px; }
  .rsm-ilt-hero .hero-visual{ max-height:360px; border-radius:16px; }
  .rsm-ilt-benefits .grid-3,
  .rsm-ilt-delivery .grid-3{ grid-template-columns:1fr; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  .rsm-ilt-benefits .card{ transition:none!important; }
}
/* ===============================
   Areas We Train In Section
   =============================== */
.rsm-ilt-areas{
  padding:48px 0 64px;
  background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%);
  border-top:1px solid rgba(15,23,42,.06);
}
.rsm-ilt-areas .head h2{
  margin:0 0 8px;
  font:800 32px/1.15 Inter,system-ui,sans-serif;
  letter-spacing:-.02em;
  color:#0b0f1a;
  text-align:center;
}
.rsm-ilt-areas .head .sub{
  margin:0 auto 28px;
  color:#475569;
  font:500 16px/1.6 Inter,system-ui,sans-serif;
  text-align:center;
  max-width:70ch;
}
.rsm-ilt-areas .areas-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
  max-width:1100px;
  margin:0 auto;
}
.rsm-ilt-areas .area{
  background:#fff;
  border:1px solid rgba(15,23,42,.1);
  border-radius:20px;
  padding:24px;
  box-shadow:0 12px 28px rgba(3,7,18,.08),0 3px 10px rgba(3,7,18,.06);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.rsm-ilt-areas .area:hover{
  transform:translateY(-2px);
  border-color:rgba(15,23,42,.16);
  box-shadow:0 16px 34px rgba(3,7,18,.12), 0 6px 16px rgba(3,7,18,.08);
}
.rsm-ilt-areas h3{
  margin:0 0 8px;
  font:800 20px/1.2 Inter,system-ui,sans-serif;
  color:#0b8067;
}
.rsm-ilt-areas ul{
  margin:0; padding-left:18px;
  color:#475569;
  font:500 14px/1.6 Inter,system-ui,sans-serif;
  columns:2;
}
.rsm-ilt-areas li{ margin-bottom:4px; }

@media (max-width:800px){
  .rsm-ilt-areas .areas-grid{ grid-template-columns:1fr; }
  .rsm-ilt-areas ul{ columns:1; }
}

/*Align ILT secondary image to the right*/
.rsm-ilt-overview .overview-img { margin-left: auto; margin-right: 0; }

/* ===============================
   RSM FAQ — Pure CSS Accordion
   =============================== */
.rsm-faq {
  background: linear-gradient(180deg,#f7fffb 0%,#ffffff 100%);
  padding: 60px 0 80px;
  border-top: 1px solid rgba(15,23,42,.06);
}
.rsm-faq .faq-header {
  text-align: center;
  max-width: 800px;
  margin: 0 auto 40px;
}
.rsm-faq .kicker {
  display:inline-block;
  background:#eafef7; color:#0b8067; border:1px solid #a7f3d0;
  border-radius:999px; font:800 12px/1 Inter,system-ui,sans-serif;
  padding:8px 12px; text-transform:uppercase; letter-spacing:.08em;
}
.rsm-faq h1 {
  font:800 36px/1.15 Inter,system-ui,sans-serif; color:#083a30; margin:16px 0 10px;
}
.rsm-faq .lead {
  font:500 16px/1.6 Inter,system-ui,sans-serif; color:#475569; margin:0;
}

.rsm-faq .faq-grid {
  max-width: 900px;
  margin: 0 auto;
  display: flex; flex-direction: column; gap: 14px;
}

/* Items */
.rsm-faq .faq-item {
  background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:18px;
  box-shadow:0 10px 24px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
  overflow:hidden; transition: box-shadow .2s ease, transform .15s ease, border-color .2s ease;
}
.rsm-faq .faq-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(3,7,18,.10), 0 6px 16px rgba(3,7,18,.08);
}

/* Toggle (hidden checkbox) */
.rsm-faq .faq-toggle { position:absolute; opacity:0; pointer-events:none; }

/* Question label */
.rsm-faq .faq-q {
  display:block;
  cursor:pointer;
  padding:18px 22px;
  margin:0;
  font:700 16px/1.4 Inter,system-ui,sans-serif;
  color:#0b0f1a;
  position:relative;
}

/* + / – icon */
.rsm-faq .faq-q::after {
  content:"+";
  position:absolute; right:20px; top:50%; transform:translateY(-50%);
  font-weight:800; color:#0b8067; transition: transform .2s ease;
}

/* Answer (collapsed by default) */
.rsm-faq .faq-a {
  max-height: 0;
  overflow: hidden;
  padding: 0 22px;
  color:#475569; font:500 15px/1.6 Inter,system-ui,sans-serif;
  transition: max-height .3s ease, padding .3s ease;
}

/* When checked: expand */
.rsm-faq .faq-toggle:checked + .faq-q::after { content:"–"; transform:translateY(-50%) rotate(90deg); }
.rsm-faq .faq-toggle:checked + .faq-q + .faq-a {
  max-height: 600px;   /* large enough to show content */
  padding: 0 22px 18px;
}

/* CTA at bottom */
.rsm-faq .faq-cta { max-width: 900px; margin: 22px auto 0; }
.rsm-faq .faq-cta .cta-card{
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  background: rgba(255,255,255,.8);
  border:1px solid rgba(15,23,42,.12);
  border-radius:18px;
  box-shadow:0 14px 32px rgba(3,7,18,.10), 0 4px 12px rgba(3,7,18,.06);
  backdrop-filter: saturate(140%) blur(6px);
  padding: 16px 18px;
}
.rsm-faq .faq-cta h3{ margin:0 0 4px; font:900 22px/1.2 Inter,system-ui,sans-serif; color:#0b0f1a; }
.rsm-faq .faq-cta p{ margin:0; color:#475569; }

@media (max-width:640px){
  .rsm-faq h1{ font-size:28px; }
  .rsm-faq .faq-q{ font-size:15px; }
}

/* Break .rsm-course-ilt sections out of the narrow column to full viewport width */
.rsm-course-ilt {
  position: relative;
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw);   /* pull to left edge of viewport */
  margin-right: calc(50% - 50vw);  /* pull to right edge of viewport */
  left: 50%;
  right: 50%;
}

/* Keep the inner content readable with your standard wrapper */
.rsm-course-ilt .rsm-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
}

/* If a parent container clips overflow, neutralize it for our blocks */
.rsm-course-ilt { overflow: visible; }
.rsm-course-ilt * { overflow: visible; }  /* only affects our section */

/* ================================
   RSM – Workshop Right Pane Card
   ================================ */
.rsm-workshop-aside { font-family: Inter,system-ui,Segoe UI,Roboto,Arial,Helvetica,sans-serif; }

/* Card shell */
.rsmw-card{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:20px;
  box-shadow:0 12px 28px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
  padding:16px;
}

/* Header */
.rsmw-head h3{
  margin:8px 0 6px;
  font:800 18px/1.2 Inter,system-ui,sans-serif;
  color:#0b0f1a;
}
.rsmw-kicker{
  display:inline-block;
  background:#eafef7;
  color:#0b8067;
  border:1px solid #a7f3d0;
  border-radius:999px;
  padding:6px 10px;
  font:800 11px/1 Inter,system-ui,sans-serif;
  text-transform:uppercase;
  letter-spacing:.08em;
}

/* Included list */
.rsmw-list{
  list-style:none; margin:10px 0 6px; padding:0;
  color:#475569; font:500 14px/1.55 Inter,system-ui,sans-serif;
}
.rsmw-list li{ display:flex; gap:10px; align-items:flex-start; }
.rsmw-list .i{ width:18px; line-height:1.4; flex:0 0 18px; color:#0b8067; font-weight:900; }

/* Section blocks */
.rsmw-divider{ height:1px; background:rgba(15,23,42,.08); border-radius:1px; margin:12px 0; }
.rsmw-block h4{
  margin:0 0 6px; color:#0b0f1a; font:800 14px/1.2 Inter,system-ui,sans-serif;
}
.rsmw-mini{ margin:0; padding-left:18px; color:#475569; font:500 14px/1.55 Inter,system-ui,sans-serif; }
.rsmw-mini li+li{ margin-top:2px; }

/* Chips */
.rsmw-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.rsmw-chips .chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 12px; border-radius:999px;
  background:#fff; color:#0f172a;
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 6px 16px rgba(3,7,18,.06);
  font:700 12px/1.1 Inter,system-ui,sans-serif;
}

/* Info grid (label/value rows) */
.rsmw-info{
  margin-top:10px; border:1px dashed rgba(11,128,103,.25);
  border-radius:14px; padding:10px; background:#f7fffb;
}
.rsmw-info .row{
  display:flex; justify-content:space-between; gap:10px;
  padding:6px 2px; color:#0f172a; font:600 13px/1.4 Inter,system-ui,sans-serif;
}
.rsmw-info .row + .row{ border-top:1px solid rgba(15,23,42,.06); }
.rsmw-info .lbl{ color:#475569; }
.rsmw-info .val{ font-weight:800; }

/* Note */
.rsmw-note{
  margin-top:10px; background:#fff; border:1px solid rgba(15,23,42,.10);
  border-radius:14px; padding:10px 12px; color:#475569; font:500 13px/1.5 Inter,system-ui,sans-serif;
  box-shadow:0 6px 14px rgba(3,7,18,.06);
}

/* CTAs */
.rsmw-cta{ display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.rsmw-cta .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 14px; border-radius:14px; text-decoration:none; font:800 13px/1 Inter,system-ui,sans-serif;
  border:1px solid transparent;
}
.rsmw-cta .btn-primary{
  background:linear-gradient(180deg,#21c296,#18b58a);
  color:#083a30; border-color:rgba(24,181,138,.35);
  box-shadow:0 10px 20px rgba(24,181,138,.25);
}
.rsmw-cta .btn-ghost{
  background:#fff; color:#0f172a; border:1px solid rgba(15,23,42,.12);
  box-shadow:0 6px 16px rgba(3,7,18,.06);
}

/* Fine print */
.rsmw-fine{ margin-top:10px; color:#65748b; font:500 12px/1.55 Inter,system-ui,sans-serif; }
/* --- Cleaner “What’s Included” block --- */
.rsmw-included {
  background: #f7fffb;
  border: 1px solid rgba(11, 128, 103, 0.15);
  border-radius: 16px;
  padding: 16px 18px;
  margin-bottom: 14px;
  box-shadow: 0 6px 16px rgba(3,7,18,.06);
}

.rsmw-included-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.rsmw-included-header .icon {
  display: inline-grid;
  place-items: center;
  background: #eafef7;
  color: #0b8067;
  border: 1px solid #a7f3d0;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  font-size: 18px;
}

.rsmw-included-header h4 {
  margin: 0;
  font: 800 16px/1.2 Inter, system-ui, sans-serif;
  color: #083a30;
}

/* Grid layout for bullet-like rows */
.rsmw-included-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.rsmw-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-top: 1px solid rgba(15,23,42,.06);
}

.rsmw-item:first-child {
  border-top: none;
}

.rsmw-item .emoji {
  flex: 0 0 26px;
  font-size: 20px;
  line-height: 1;
}

.rsmw-item strong {
  color: #0b0f1a;
  font-weight: 700;
  display: block;
  margin-bottom: 2px;
}

.rsmw-item p {
  color: #475569;
  font-size: 14px;
  line-height: 1.5;
  margin: 0;
}

/* Optional hover detail effect */
.rsmw-item:hover {
  background: rgba(233, 251, 245, 0.5);
  border-radius: 10px;
  transition: background 0.2s ease;
}

@media (max-width: 640px) {
  .rsmw-included {
    padding: 14px;
  }
  .rsmw-item .emoji {
    font-size: 18px;
  }
}
/* ===== RSM – Course Overview block ===== */
.rsm-overview{ background:linear-gradient(180deg,#f7fffb 0%, #ffffff 100%); border:1px solid rgba(15,23,42,.08); border-radius:22px; box-shadow:0 12px 28px rgba(3,7,18,.08),0 3px 10px rgba(3,7,18,.06); padding:22px; margin:14px 0; }
.rsm-ov-wrap{ max-width: 1100px; margin:0 auto; }
.rsm-overview .kicker{ display:inline-block; background:#eafef7; color:#0b8067; border:1px solid #a7f3d0; border-radius:999px; padding:6px 10px; font:800 11px/1 Inter,system-ui,sans-serif; letter-spacing:.08em; text-transform:uppercase; }
.rsm-overview h2{ margin:10px 0 6px; font:800 28px/1.2 Inter,system-ui,sans-serif; color:#0b0f1a; letter-spacing:-.02em; }
.rsm-overview .lead{ margin:0 0 12px; color:#475569; font:500 15px/1.65 Inter,system-ui,sans-serif; max-width:70ch; }
.rsm-overview .btn{ display:inline-flex; align-items:left; justify-content:left; gap:8px; padding:10px 14px; border-radius:14px; font:800 13px/1 Inter,system-ui,sans-serif; text-decoration:none; border:1px solid rgba(15,23,42,.12); background:#fff; color:#0f172a; box-shadow:0 6px 16px rgba(3,7,18,.06); }
.rsm-overview .btn:hover{ filter:brightness(.98); }
/* Overview grid: full-width, two equal cards */
.rsm-ov-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 16px;
  width: 100%;
}

/* Stretch cards evenly and balance padding */
.rsm-ov-card {
  background: #fff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 20px 22px;
  box-shadow: 0 10px 24px rgba(3,7,18,.08), 0 3px 10px rgba(3,7,18,.06);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}

/* Add slight lift on hover for interactivity */
.rsm-ov-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(3,7,18,.12), 0 6px 16px rgba(3,7,18,.08);
  border-color: rgba(15,23,42,.16);
}

/* Inner text and bullets remain consistent */
.rsm-ov-card h3 {
  margin: 6px 0 8px;
  font: 800 18px/1.25 Inter, system-ui, sans-serif;
  color: #0b0f1a;
}

.rsm-ov-card .bullets {
  margin: 8px 0 0 18px;
  color: #475569;
  font: 500 14px/1.55 Inter, system-ui, sans-serif;
}

.rsm-ov-card .icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #eafef7;
  color: #0b8067;
  border: 1px solid #a7f3d0;
  font-size: 18px;
  font-weight: 900;
  margin-bottom: 8px;
}

/* Responsive layout */
@media (max-width: 900px) {
  .rsm-ov-grid {
    grid-template-columns: 1fr;
  }
}

.rsm-ov-card{ background:#fff; border:1px solid rgba(15,23,42,.10); border-radius:18px; padding:16px; box-shadow:0 10px 24px rgba(3,7,18,.08),0 3px 10px rgba(3,7,18,.06); }
.rsm-ov-card .icon{ width:40px; height:40px; border-radius:12px; display:grid; place-items:center; background:#eafef7; color:#0b8067; border:1px solid #a7f3d0; font-size:18px; font-weight:900; margin-bottom:6px; }
.rsm-ov-card h3{ margin:4px 0 6px; font:800 16px/1.2 Inter,system-ui,sans-serif; color:#0b0f1a; }
.rsm-ov-card .bullets{ margin:6px 0 0 18px; color:#475569; font:500 14px/1.55 Inter,system-ui,sans-serif; }
.rsm-ov-meta{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.rsm-ov-meta .chip{ display:inline-flex; align-items:center; gap:6px; padding:8px 12px; border-radius:999px; background:#fff; color:#0f172a; border:1px solid rgba(15,23,42,.10); box-shadow:0 6px 16px rgba(3,7,18,.06); font:700 12px/1.1 Inter,system-ui,sans-serif; }
@media (max-width:1000px){ .rsm-ov-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .rsm-ov-grid{ grid-template-columns:1fr; } .rsm-overview h2{ font-size:24px; } }

/* ==== RSM Overview polish (sleeker + organized) ==== */

/* Header: left, tighter rhythm */
.rsm-overview .rsm-ov-head{ text-align:left; margin-bottom:16px; }
.rsm-overview .kicker{ margin-bottom:6px; }
.rsm-overview h2{
  margin:6px 0 6px;
  font:800 32px/1.15 Inter,system-ui,sans-serif;
  letter-spacing:-.02em; color:#0b0f1a;
}
.rsm-overview .lead{
  margin:0 0 10px; max-width:62ch;
  color:#475569; font:500 15px/1.6 Inter,system-ui,sans-serif;
}
.rsm-overview .btn{ margin-top:6px; }

/* Optional: thin divider between header and cards */
.rsm-overview .rsm-ov-sep{
  height:1px; background:rgba(15,23,42,.08);
  border-radius:1px; margin:14px 0 10px;
}

/* Grid: full-width, equal height cards */
.rsm-ov-grid{
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:16px; align-items:stretch; width:100%; margin-top:12px;
}

/* Card: subtler look, tighter padding */
.rsm-ov-card{
  background:#fff; border:1px solid rgba(15,23,42,.08);
  border-radius:16px; padding:18px 20px;
  box-shadow:0 10px 22px rgba(3,7,18,.07), 0 3px 10px rgba(3,7,18,.05);
  transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.rsm-ov-card:hover{
  transform:translateY(-1px);
  border-color:rgba(15,23,42,.14);
  box-shadow:0 16px 32px rgba(3,7,18,.10), 0 6px 16px rgba(3,7,18,.08);
}

/* Card header + icon badge */
.rsm-ov-card .icon{
  width:36px; height:36px; border-radius:10px;
  display:grid; place-items:center; margin-bottom:8px;
  background:#eafef7; color:#0b8067; border:1px solid #a7f3d0; font-weight:900;
}
.rsm-ov-card h3{
  margin:2px 0 8px; color:#0b0f1a;
  font:800 17px/1.25 Inter,system-ui,sans-serif;
}

/* Bullets: cleaner spacing; 2 columns on wide screens */
.rsm-ov-card .bullets{
  margin:0; padding-left:18px;
  color:#475569; font:500 14px/1.55 Inter,system-ui,sans-serif;
}
.rsm-ov-card .bullets li + li{ margin-top:4px; }
@media (min-width: 980px){
  .rsm-ov-card .bullets{ columns:2; column-gap:24px; }
}

/* Meta chips: sleeker, neutral */
.rsm-ov-meta{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.rsm-ov-meta .chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 12px; border-radius:999px; font:700 12px/1.1 Inter,system-ui,sans-serif;
  background:#f8fafc; color:#0f172a; border:1px solid rgba(15,23,42,.10);
  box-shadow:none;
}

/* Responsive: stack cards on small screens */
@media (max-width: 900px){
  .rsm-ov-grid{ grid-template-columns:1fr; }
}

/* Center the Overview title + description only */
.rsm-overview .rsm-ov-head {
  text-align: center;
  margin-bottom: 20px;
}

.rsm-overview .rsm-ov-head h2 {
  font: 800 34px/1.2 Inter, system-ui, sans-serif;
  color: #0b0f1a;
  letter-spacing: -0.02em;
  margin: 8px 0 10px;
}

.rsm-overview .rsm-ov-head .lead {
  text-align: center;
  margin: 0 auto 16px;
  max-width: 70ch;
  color: #475569;
  font: 500 16px/1.65 Inter, system-ui, sans-serif;
}

/* Center the button under the paragraph */
.rsm-overview .rsm-ov-head .btn {
  display: inline-flex;
  justify-content: center;
  margin-top: 8px;
}
/* Overview action buttons layout */
.rsm-ov-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 16px;
}

.rsm-ov-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 20px;
  border-radius: 14px;
  font: 800 14px/1 Inter, system-ui, sans-serif;
  text-decoration: none;
  border: 1px solid transparent;
  transition: transform 0.15s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

/* Primary gradient button */
.rsm-ov-actions .btn-primary {
  background: linear-gradient(180deg, #21c296, #18b58a);
  color: #083a30;
  border-color: rgba(24,181,138,0.35);
  box-shadow: 0 10px 20px rgba(24,181,138,0.25);
}
.rsm-ov-actions .btn-primary:hover { filter: brightness(1.05); transform: translateY(-1px); }

/* Secondary white button */
.rsm-ov-actions .btn-secondary {
  background: #ffffff;
  color: #0f172a;
  border: 1px solid rgba(15,23,42,0.12);
  box-shadow: 0 6px 16px rgba(3,7,18,0.06);
}
.rsm-ov-actions .btn-secondary:hover { filter: brightness(0.98); }

/* Outline (pricing) button */
.rsm-ov-actions .btn-outline {
  background: transparent;
  color: #0b8067;
  border: 1.5px solid #0b8067;
  box-shadow: 0 4px 12px rgba(11,128,103,0.08);
}
.rsm-ov-actions .btn-outline:hover {
  background: #eafef7;
  color: #0b0f1a;
  transform: translateY(-1px);
}

/* Responsive button stack */
@media (max-width: 700px) {
  .rsm-ov-actions {
    flex-direction: column;
    align-items: center;
  }
  .rsm-ov-actions .btn { width: 100%; max-width: 320px; }
}
/* --- Restore normal two-column layout on course pages --- */

/* 1) Reset any full-bleed rules that were applied too broadly */
body[class*="course"] section {
  width: auto !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* 2) Keep full-bleed ONLY when it’s inside your explicit takeover wrapper */
#rsm-ilt-root section {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

/* 3) Make sure the main row still behaves like a 2-column grid */
body[class*="course"] .row {
  display: flex !important;
  flex-wrap: nowrap;
}
body[class*="course"] .row > [class*="col-"] {
  float: none !important;   /* neutralize float-based layouts */
}

/* Optional: enforce sane column widths if your theme uses flex */
body[class*="course"] [class*="left"],
body[class*="course"] [class*="primary"] { flex: 1 1 68%; min-width: 0; }
body[class*="course"] [class*="right"],
body[class*="course"] [class*="sidebar"],
body[class*="course"] [class*="secondary"] { flex: 0 0 32%; min-width: 280px; }

/***** Keep the right pane on the right beside the Overview *****/

/* Make ONLY the row that contains our overview act like a two-column layout */
.row:has(#rsm-ov-root),
.columns:has(#rsm-ov-root) {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: flex-start !important;
}

/* Left/main column = the one that contains #rsm-ov-root */
.row:has(#rsm-ov-root) > *:has(#rsm-ov-root),
.columns:has(#rsm-ov-root) > *:has(#rsm-ov-root) {
  order: 1;
  flex: 1 1 68% !important;   /* main column */
  min-width: 0 !important;
  float: none !important;
}

/* Right/sidebar column = the sibling NOT containing #rsm-ov-root */
.row:has(#rsm-ov-root) > *:not(:has(#rsm-ov-root)),
.columns:has(#rsm-ov-root) > *:not(:has(#rsm-ov-root)) {
  order: 2;
  flex: 0 0 32% !important;   /* sidebar width */
  min-width: 280px !important;
  max-width: 520px !important;
  float: none !important;
}

/* Neutralize any overly-broad full-bleed rules inside THIS row only */
.row:has(#rsm-ov-root) section,
.columns:has(#rsm-ov-root) section {
  width: auto !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Ensure our overview itself isn't made full-bleed elsewhere */
#rsm-ov-root,
#rsm-ov-root .rsm-overview {
  width: auto !important;
  max-width: 100% !important;
  margin: 0 !important;
}

/* Safety: kill legacy floats in this row */
.row:has(#rsm-ov-root) > *,
.columns:has(#rsm-ov-root) > * {
  float: none !important;
}

/* Responsive: stack on small screens */
@media (max-width: 900px){
  .row:has(#rsm-ov-root),
  .columns:has(#rsm-ov-root) { flex-wrap: wrap !important; }
  .row:has(#rsm-ov-root) > *:has(#rsm-ov-root),
  .columns:has(#rsm-ov-root) > *:has(#rsm-ov-root),
  .row:has(#rsm-ov-root) > *:not(:has(#rsm-ov-root)),
  .columns:has(#rsm-ov-root) > *:not(:has(#rsm-ov-root)) {
    flex: 1 1 100% !important;
    max-width: 100% !important;
  }
}
/* === Stack "What you'll learn" and "Ideal for" cards vertically === */
.rsm-ov-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;            /* spacing between cards */
}

.rsm-ov-card {
  width: 100%;
  max-width: 100%;
}
