/* ============================================================
   MW The Class Room - front-end styles.
   Scoped under .mwcr, every class prefixed mwcr- so it never
   collides with (or inherits from) the active theme.
   ============================================================ */

body.mwcr-page{overflow-x:hidden} /* allow .mwcr full-bleed without a scrollbar */

/* Strip the theme's content/sidebar padding so the section sits flush */
body.mwcr-page #main,
body.mwcr-page #primary,
body.mwcr-page #content,
body.mwcr-page #sidebar-primary,
body.mwcr-page #sidebar-secondary{padding-top:0!important;padding-bottom:0!important}

.mwcr{
  --bg:#060a14;--bg2:#0a1122;--panel:#0e1830;--panel2:#101c38;
  --line:rgba(255,255,255,.09);--line2:rgba(255,255,255,.16);
  --ink:#eaf0ff;--muted:#94a3c4;--muted2:#6b779a;
  --brand:#2f6bff;--brand2:#5b8cff;--brand3:#7aa2ff;
  --green:#1fd17b;--green-soft:rgba(31,209,123,.14);
  --gold:#f6b545;--red:#ff5d6c;
  --radius:20px;--radius-sm:14px;--shadow:0 30px 60px -25px rgba(0,0,0,.8);
  --card-w:248px;
  --font:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:"Space Grotesk","Inter",system-ui,sans-serif;
  /* full-bleed out of the theme's content container */
  position:relative;left:50%;right:50%;width:100vw;margin-left:-50vw;margin-right:-50vw;
  overflow:hidden;isolation:isolate;padding:0 0 26px;
  font-family:var(--font);color:var(--ink);line-height:1.5;
  background:
    radial-gradient(900px 600px at 82% -8%, rgba(47,107,255,.20), transparent 60%),
    radial-gradient(820px 600px at 0% 6%, rgba(31,209,123,.10), transparent 55%),
    linear-gradient(180deg,#060a14 0%, #0a1122 42%, #060a14 100%);
}
.mwcr::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.30;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(circle at 50% 0%, #000 0%, transparent 72%);
  mask-image:radial-gradient(circle at 50% 0%, #000 0%, transparent 72%)}
.mwcr *{box-sizing:border-box}
.mwcr a{color:inherit;text-decoration:none}
.mwcr a:link,.mwcr a:visited,.mwcr a:hover,.mwcr a:focus,.mwcr a:active{text-decoration:none!important}
.mwcr h1,.mwcr h2,.mwcr h3,.mwcr h4,.mwcr p{margin:0;color:inherit}
.mwcr button{font-family:inherit}
.mwcr-wrap{position:relative;z-index:1;max-width:1240px;margin:0 auto;padding:0 24px}

/* ---------- hero (minimal: title + subtitle) ---------- */
.mwcr-hero{position:relative;padding:74px 24px 22px;text-align:center}
.mwcr-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-size:12px;font-weight:600;letter-spacing:2.4px;color:var(--brand3);text-transform:uppercase;background:rgba(47,107,255,.1);border:1px solid rgba(47,107,255,.3);padding:7px 15px;border-radius:999px}
.mwcr-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px var(--green-soft);animation:mwcr-pulse 2s infinite}
@keyframes mwcr-pulse{50%{box-shadow:0 0 0 8px transparent}}
.mwcr-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(40px,6.4vw,72px);line-height:1.02;margin:22px auto 0;max-width:16ch;letter-spacing:-1.4px}
.mwcr-grad{background:linear-gradient(100deg,var(--brand2),var(--green));-webkit-background-clip:text;background-clip:text;color:transparent}
.mwcr .mwcr-sub{max-width:62ch;margin:20px auto 0;color:var(--muted);font-size:clamp(15px,2vw,18px)}
.mwcr-rule{width:min(680px,82%);height:1px;margin:38px auto 0;border:0;background:linear-gradient(90deg,transparent,var(--line2),transparent)}

/* ---------- category sections ---------- */
.mwcr-cats{padding:8px 0 0}
.mwcr-cat{margin-top:42px}
.mwcr-cat:first-child{margin-top:18px}
.mwcr-cat-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin:0 0 18px}
.mwcr-kicker{font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--brand3)}
.mwcr-cat-head h2{font-family:var(--display);font-size:clamp(22px,3vw,30px);letter-spacing:-.5px;margin:6px 0 0;display:flex;align-items:center;gap:12px}
.mwcr-count{font-family:var(--font);font-size:12px;font-weight:600;color:var(--muted2);background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:999px;padding:3px 10px;letter-spacing:0}
.mwcr-cat-sub{color:var(--muted);font-size:14px;margin:7px 0 0;max-width:60ch}
.mwcr-viewall,.mwcr-viewall:visited{display:inline-flex;align-items:center;gap:6px;color:var(--brand3);font-weight:600;font-size:14px;white-space:nowrap}
.mwcr-viewall:hover{color:#fff}
.mwcr-viewall svg{width:15px;height:15px;transition:transform .2s}
.mwcr-viewall:hover svg{transform:translateX(3px)}

/* ---------- shelf (2-row horizontal slider) ---------- */
.mwcr-shelf{position:relative}
.mwcr-track-wrap{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;
  scrollbar-width:none;-ms-overflow-style:none;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 26px,#000 calc(100% - 26px),transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 26px,#000 calc(100% - 26px),transparent 100%);
  transition:-webkit-mask-image .25s, mask-image .25s}
.mwcr-shelf.at-start .mwcr-track-wrap{-webkit-mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 26px),transparent 100%);
  mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 26px),transparent 100%)}
.mwcr-shelf.at-end .mwcr-track-wrap{-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 26px,#000 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 26px,#000 100%)}
.mwcr-shelf:not(.scrollable) .mwcr-track-wrap{-webkit-mask-image:none;mask-image:none}
.mwcr-track-wrap::-webkit-scrollbar{display:none}
.mwcr-track{display:grid;grid-auto-flow:column;grid-template-rows:repeat(2,auto);
  grid-auto-columns:var(--card-w);gap:18px;padding:6px 2px}
/* JS adds .mwcr-onerow when every card fits across one row, so a short shelf
   shows a single row instead of a half-empty double row. */
.mwcr-shelf.mwcr-onerow .mwcr-track{grid-template-rows:auto}

/* nav buttons */
.mwcr-navbtn{position:absolute;top:50%;transform:translateY(-50%) scale(.9);z-index:6;
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  border:1px solid var(--line2);background:rgba(10,17,34,.74);backdrop-filter:blur(8px);
  color:#fff;opacity:0;pointer-events:none;transition:opacity .22s, transform .22s, background .2s}
.mwcr-navbtn svg{width:20px;height:20px}
.mwcr-navbtn.prev{left:-10px}
.mwcr-navbtn.next{right:-10px}
.mwcr-navbtn.show{opacity:1;pointer-events:auto;transform:translateY(-50%) scale(1)}
.mwcr-navbtn:hover{background:linear-gradient(135deg,var(--brand2),var(--brand));border-color:transparent;transform:translateY(-50%) scale(1.08)}
.mwcr-navbtn:focus-visible{outline:2px solid var(--brand2);outline-offset:2px}

/* ---------- card (thumbnail + title only) ---------- */
.mwcr-card,.mwcr-card:visited{display:block;background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;scroll-snap-align:start;
  color:inherit;transition:transform .25s, border-color .25s, box-shadow .25s}
.mwcr-card:hover{transform:translateY(-6px);border-color:var(--line2);box-shadow:var(--shadow)}
.mwcr-card:focus-visible{outline:2px solid var(--brand2);outline-offset:2px}
.mwcr-thumb{position:relative;display:block;aspect-ratio:16/9;overflow:hidden;background:#0a1430}
.mwcr-thumb .mwcr-img,.mwcr-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.mwcr-card:hover .mwcr-thumb img{transform:scale(1.05)}
.mwcr-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(3,6,14,.35) 100%)}
.mwcr-ph{position:absolute;inset:0;display:block;background:linear-gradient(135deg,var(--g1,#1b3a8f),var(--g2,#0a1430))}
.mwcr-ph .mwcr-art{position:absolute;inset:0;width:100%;height:100%}
.mwcr-card-t{padding:12px 14px 15px;font-family:var(--display);font-weight:600;font-size:14.5px;line-height:1.34;color:#fff;
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  height:calc(2.68em + 27px)} /* exactly 2 lines + padding, so every card is equal height */

/* ---------- empty states ---------- */
.mwcr-cat-empty,.mwcr-empty-note{color:var(--muted);font-size:14px;border:1px dashed var(--line);border-radius:14px;padding:18px 20px}
.mwcr-empty-note a{color:var(--brand3);font-weight:600}

/* ---------- training-video cards ---------- */
.mwcr-vcard{cursor:pointer}
.mwcr-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:rgba(5,9,18,.55);border:1px solid var(--line2);backdrop-filter:blur(4px);transition:transform .25s,background .25s,border-color .25s}
.mwcr-play svg{width:24px;height:24px;color:#fff;margin-left:3px}
.mwcr-vcard:hover .mwcr-play{transform:translate(-50%,-50%) scale(1.08);background:linear-gradient(135deg,var(--brand2),var(--brand));border-color:transparent}
.mwcr-vcard:focus-visible{outline:2px solid var(--brand2);outline-offset:2px}

/* ---------- video lightbox ---------- */
.mwcr-lb{position:fixed;inset:0;z-index:99999;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}
.mwcr-lb.active{display:flex;opacity:1}
.mwcr-lb-overlay{position:absolute;inset:0;background:rgba(3,6,14,.86);backdrop-filter:blur(6px)}
.mwcr-lb-content{position:relative;width:92%;max-width:1040px;transform:scale(.94);transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}
.mwcr-lb.active .mwcr-lb-content{transform:scale(1)}
.mwcr-lb-frame{position:relative;width:100%;padding-top:56.25%;background:#000;border-radius:14px;overflow:hidden;box-shadow:0 30px 60px -15px rgba(0,0,0,.7);border:1px solid var(--line2)}
.mwcr-lb-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.mwcr-lb-close{position:absolute;top:-48px;right:0;width:38px;height:38px;border-radius:50%;border:1px solid var(--line2);background:rgba(255,255,255,.06);color:#fff;font-size:22px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .2s}
.mwcr-lb-close:hover{background:rgba(255,255,255,.16);transform:scale(1.06)}
.mwcr-lb-cap{margin-top:14px;text-align:center;font-family:var(--display);font-size:15px;color:var(--ink);opacity:.92}

/* ---------- reveal ---------- */
.mwcr-reveal{opacity:0;transform:translateY(22px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}
.mwcr-reveal.mwcr-in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:760px){
  .mwcr{--card-w:200px}
  .mwcr-hero{padding:50px 22px 12px}
  .mwcr-navbtn{display:none} /* swipe on touch */
  .mwcr-track-wrap{-webkit-mask-image:none;mask-image:none}
  .mwcr-cat-head{align-items:flex-start}
}
@media(max-width:430px){.mwcr{--card-w:168px}}
@media(prefers-reduced-motion:reduce){
  .mwcr *,.mwcr *::before,.mwcr *::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .mwcr-reveal{opacity:1;transform:none}
}
