@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; }
}

/* ===== Dynamic Workshop Hero ===== */
.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-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-hero-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-hero-left h1{
  font:800 40px/1.15 Inter,Arial,Helvetica,sans-serif;
  letter-spacing:-.02em; color:#083a30;
  margin:14px 0 10px;
}
.rsm-hero-left .lead{
  max-width:62ch; color:#334155; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif;
  margin:0 0 20px;
}
.rsm-hero-actions{ display:flex; flex-wrap:wrap; gap:12px; }
.rsm-hero-actions .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;
}
.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);
}
.btn-secondary{
  background:#fff; color:#0f172a;
  border:1px solid rgba(15,23,42,.12);
  box-shadow:0 6px 16px rgba(3,7,18,.06);
}
.rsm-hero-right img.hero-img{
  max-width:100%; height:auto; max-height:480px; border-radius:22px;
  box-shadow:0 12px 28px rgba(3,7,18,.14), 0 3px 10px rgba(3,7,18,.10);
}

/* ================================
   RSM Course Cleanup (Right Sidebar)
   Makes course pages full-width
   ================================ */

/* Keep spacing under your custom hero */
body[class*="course"] .rsm-workshops-hero { margin-bottom: 12px; }

/* 1) Hide RIGHT rail (cover common TI variants) */
body[class*="course"] .course-sidebar-right,
body[class*="course"] [class*="right-rail"],
body[class*="course"] [class*="rightcol"],
body[class*="course"] [class*="right-col"],
body[class*="course"] aside[class*="right"],
body[class*="course"] .sidebar--right,
body[class*="course"] .ti-course__sidebar--right,
body[class*="course"] [role="complementary"],
body[class*="course"] aside[class*="sidebar"],
body[class*="course"] [class*="sidebar"]:not(.rsm-hero) {
  display: none !important;
}

/* 2) Expand main column to full width */
body[class*="course"] .course-layout,
body[class*="course"] [class*="layout"],
body[class*="course"] .container {
  display: block !important;      /* neutralize grid/flex wrappers */
}
body[class*="course"] .course-main,
body[class*="course"] [class*="main-col"],
body[class*="course"] [class*="content-col"],
body[class*="course"] [class*="lo-body"],
body[class*="course"] [role="main"] {
  width: 100% !important;
  max-width: 1200px !important;
  margin-inline: auto !important;
  padding-inline: 24px !important;
  float: none !important;
}

/* 3) (Optional) Hide duplicate native header/title/breadcrumb so your hero is the only header */
body[class*="course"] .course-header,
body[class*="course"] [class*="lo-header"],
body[class*="course"] h1.course-title,
body[class*="course"] [class*="title-block"],
body[class*="course"] nav.breadcrumbs {
  display: none !important;
}

/* ===== Dynamic Workshop Hero ===== */
.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-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-hero-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-hero-left h1{
  font:800 40px/1.15 Inter,Arial,Helvetica,sans-serif;
  letter-spacing:-.02em; color:#083a30;
  margin:14px 0 10px;
}
.rsm-hero-left .lead{
  max-width:62ch; color:#334155; font:500 16px/1.6 Inter,Arial,Helvetica,sans-serif;
  margin:0 0 20px;
}
.rsm-hero-actions{ display:flex; flex-wrap:wrap; gap:12px; }
.rsm-hero-actions .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;
}
.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);
}
.btn-secondary{
  background:#fff; color:#0f172a;
  border:1px solid rgba(15,23,42,.12);
  box-shadow:0 6px 16px rgba(3,7,18,.06);
}
.rsm-hero-right img.hero-img{
  max-width:100%; height:auto; max-height:480px; border-radius:22px;
  box-shadow:0 12px 28px rgba(3,7,18,.14), 0 3px 10px rgba(3,7,18,.10);
}

/* Overview / details */
.rsm-course-details{ padding:60px 0; background:#fff; }
.rsm-course-details h2{ font:800 28px/1.15 Inter,Arial,Helvetica,sans-serif; color:#0b0f1a; margin-bottom:14px; }
.rsm-course-details p{ color:#475569; font:500 15px/1.6 Inter,Arial,Helvetica,sans-serif; max-width:80ch; }
.rsm-course-details .course-meta{ list-style:none; margin:18px 0 0; padding:0; color:#0f172a; }
.rsm-course-details .course-meta li{ margin-bottom:8px; font:500 14px/1.5 Inter,Arial,Helvetica,sans-serif; }

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