/* === BEGIN: Shelter Learniverse SITE CSS (Homepage v7.25 + .slb v1.4.3-slow) === */
/* Section 1: HOMEPAGE CSS (UNCHANGED) */
/* =======================================================================
   KSMP Shelter Learniverse — Modern UI Styles (sitewide) v7.25
   Built: 2025-09-23
   -----------------------------------------------------------------------
   GOAL
   - Based on v7.24.
   - Increase line-height of hero body text from 1.65 to 1.7 for better readability.
   ======================================================================= */

:root{
  --brand:#0e8296; --brand-strong:#0c6f80; --brand-visited-light:#15a7bb;
  --ink:#1f2d2f; --bg:#f7f9fa; --card:#ffffff; --muted:#6b7a80;
  --radius-lg:16px; --radius-md:12px; --radius-sm:8px;
  --shadow-1:0 1px 8px rgba(13,30,55,.05);
  --shadow-2:0 2px 14px rgba(13,30,55,.06);
  --shadow-3:0 4px 18px rgba(0,0,0,.12);
}

/* ---------- Base container ---------- */
.container{
  width:100%;
  max-width:min(1400px,calc(100vw - 64px));
  margin:0 auto;
  padding:0 clamp(12px,3vw,24px);
  box-sizing:border-box;
}

/* ---------- Typography ---------- */
.h1,.h2,.h3{ font-family:"Montserrat",Arial,Helvetica,sans-serif; color:var(--ink); }
.h1{ font-weight:800; font-size:clamp(28px,3.1vw,40px); line-height:1.25; }
.h2{ font-weight:800; font-size:clamp(27px,3.1vw,38px); line-height:1.25; }
.h3{ font-weight:700; font-size:18px; line-height:1.3; }

/* ---------- Buttons ---------- */
.pill,.pill-outline{
  display:inline-block; font-family:"Montserrat",Arial,Helvetica,sans-serif; font-weight:700;
  text-decoration:none!important; border-radius:999px; padding:12px 18px; line-height:1.1;
  background:var(--brand); color:#fff!important; border:2px solid transparent; transition:all .25s ease; text-align:center;
  white-space:nowrap;
}
.pill:hover,.pill-outline:hover{ background:var(--brand-strong)!important; transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.2); }
.pill:active,.pill-outline:active{ transform:scale(.96); box-shadow:0 2px 6px rgba(0,0,0,.15); }
.pill:visited,.pill-outline:visited{ background:var(--brand-visited-light)!important; color:#fff!important; }

/* ---------- Cards & tiles ---------- */
.card,.tile{
  background:var(--card); border:1px solid #e8eef2; border-radius:var(--radius-md); box-shadow:var(--shadow-1);
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  box-sizing:border-box;
}
.card:hover,.tile:hover{ transform:translateY(-3px); box-shadow:var(--shadow-2); border-color:color-mix(in srgb,var(--brand) 15%,#e8eef2); }

.zoomable{ overflow:hidden; border-radius:var(--radius-sm); }
.zoomable img{ display:block; width:100%; height:auto; transition:transform .35s ease; }
.zoomable:hover img{ transform:scale(1.04); }

/* ---------- Section helpers ---------- */
.section{ margin-block:clamp(20px,4vw,40px); }

/* Full-bleed diagonal sections */
.bleed{ position:relative; width:100dvw; max-width:100dvw!important; margin-left:calc(50% - 50dvw); margin-right:calc(50% - 50dvw); }
@media (max-width: 820px){
  .bleed{ width:100%; max-width:100%; margin-left:auto; margin-right:auto; }
}

html, body{ overflow-x:hidden; }
.hero{ overflow-x:clip; }

main,.page,.page-content,.content,.portal-content,.wrapper{ overflow:visible!important; }

/* ---------- Motion ---------- */
@keyframes slup{ from{opacity:0; transform:translateY(18px);} to{opacity:1; transform:none;} }
.reveal{ opacity:0; transform:translateY(18px); will-change:opacity,transform; }
.reveal.in{ opacity:1; transform:none; animation:slup .6s ease var(--d,0s) both; }

/* ================== HERO ================== */
.hero{ position:relative; }
.hero .container{
  --hero-gutter: clamp(20px, 6vw, 72px);
  padding-block:64px;
  padding-inline: var(--hero-gutter) !important;
  box-sizing:border-box;
}
.hero .hero-inner{ max-width:1360px; margin-inline:auto; display:flex; flex-direction:column; gap:20px; align-items:stretch; }
.hero .hero-figure{ display:flex; justify-content:flex-start; align-items:center; }
.hero .hero-figure figure{ margin:0; text-align:left; }
.hero .hero-figure img{
  width:100%; height:auto; object-fit:contain;
  max-height:clamp(500px, 60vh, 900px);
}
.hero .hero-copy{ width:100%; max-width:none; }
.hero .hero-copy.card{
  background:var(--card); border:1px solid #e8eef2; border-radius:16px; box-shadow:var(--shadow-3);
  padding: clamp(22px, 2.2vw, 32px) clamp(22px, 2.6vw, 34px);
  box-sizing:border-box;
}
/* Increase internal spacing for hero card content */
.hero .hero-copy h1{ margin-bottom:20px; }
.hero .hero-copy p{ margin-bottom:20px; font-size:18px; line-height:1.7; }
.hero .hero-copy .pill,.hero .hero-copy .pill-outline{ margin-top:6px; }

/* GRID for tablet/desktop */
@media (min-width: 700px){
  .hero .hero-inner{ display:grid; grid-template-columns: 58% 42%; align-items:center; gap:clamp(20px, 3vw, 32px); }
}
@media (min-width: 1200px){
  .hero .hero-inner{ grid-template-columns: 56% 44%; }
}
@media (min-width: 700px) and (max-width: 1400px){
  .hero .hero-figure img{ max-height:clamp(560px, 68vh, 940px); }
}
@media (orientation:landscape) and (max-width: 900px){
  .hero .hero-inner{ grid-template-columns: 58% 42%; }
  .hero .hero-figure img{ max-height:clamp(480px, 66vh, 860px); }
}

/* Small-phone portrait */
@media (max-width: 580px){
  .hero .container{
    --hero-gutter: max(16px, 5vw, env(safe-area-inset-left), env(safe-area-inset-right));
    --hero-stack-width: min(640px, calc(100vw - (2 * var(--hero-gutter))));
    padding-left:var(--hero-gutter)!important; padding-right:var(--hero-gutter)!important; padding-block:22px;
  }
  .hero .hero-inner{ flex-direction:column; gap:14px; max-width:none; }
  .hero .hero-copy,.hero .hero-figure{ width:var(--hero-stack-width); max-width:var(--hero-stack-width); margin-left:auto; margin-right:auto; box-sizing:border-box; }
  .hero .hero-copy{ order:1; padding:clamp(16px, 2.6vw, 20px) clamp(16px, 3vw, 22px); }
  .hero .hero-copy .pill,.hero .hero-copy .pill-outline{ display:block; width:100%; max-width:100%; white-space:normal; text-align:center; margin-top:8px; }
  .hero .hero-figure{ order:2; }
  .hero .hero-figure img{ max-height:clamp(460px, 74vh, 980px); width:100%; height:auto; object-fit:contain; }
}

/* === HERO text-card width tuning (A/B test) === */
@media (min-width: 700px){
  .hero.edgefix:not(.bleed) .hero-inner{ grid-template-columns: 44% 56%; }
  .hero.edgefix.bleed .hero-inner{ grid-template-columns: 40% 60%; }
  .hero .hero-copy{ max-width:100%; }
}
@media (min-width: 1200px){
  .hero.edgefix:not(.bleed) .hero-inner{ grid-template-columns: 42% 58%; }
  .hero.edgefix.bleed .hero-inner{ grid-template-columns: 38% 62%; }
}

/* ================== SCS ================== */
.scs .section-lead.right{ text-align:right; margin:0 0 18px; }
.scs .h2{ font-size:clamp(28px,3vw,36px); }
.scs p{ font-size:18px; line-height:1.65; }
.scs-grid{ display:grid; gap:24px; }
@media(min-width:1100px){ .scs-grid{ grid-template-columns:repeat(3, minmax(0,1fr)); } }
@media(min-width:640px) and (max-width:1099px){ .scs-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); } }
@media(max-width:639px){ .scs-grid{ grid-template-columns:1fr; } }
.scs-grid .tile{ padding:12px!important; display:flex; flex-direction:column; }
.scs-grid .tile h3{ margin:0 0 6px; }
.scs-grid .tile p.small{ margin:4px 0 12px; font-size:14px; color:var(--muted); }
.scs-grid .tile .pill{ display:inline-block; width:auto; align-self:flex-start; }

/* ================== Generic 3-up grids ================== */
.grid-3{ display:grid; gap:16px; grid-auto-flow:dense; }
@media(min-width:1100px){ .grid-3{ grid-template-columns:repeat(3, minmax(0,1fr)); } }
@media(min-width:640px) and (max-width:1099px){ .grid-3{ grid-template-columns:repeat(2, minmax(0,1fr)); } }
@media(max-width:639px){ .grid-3{ grid-template-columns:1fr; } }
.tile{ display:flex; flex-direction:column; }
.tile figure{ margin:0 0 14px!important; aspect-ratio:16/9; }
.tile h3{ margin:0 0 8px!important; }
.tile p{ margin:0 0 16px!important; font-size:17px; line-height:1.6; }
.tile .pill{ margin-top:auto; }
@media(min-width:640px) and (max-width:1099px){ .grid-3 .collapse-feature{ grid-column:1 / -1; order:-1; } }
.resources figure,.resources .zoomable{ margin:0 auto; text-align:center; }

/* ================== Mission ================== */
.mission .h2{ font-size:clamp(27px,3.1vw,38px); }
.mission .body{ font-size:19px; line-height:1.7; }
.mission .card{ padding:28px!important; }

/* ================== Footer attribution ================== */
.footer-teal{ background:var(--brand); color:#fff; border-radius:14px; padding:clamp(14px,2.2vw,20px) clamp(16px,3vw,24px); }
.footer-teal,.footer-teal *{ color:#fff!important; }
.footer-teal p{ margin:0; font-family:"Montserrat",Arial,Helvetica,sans-serif!important; font-weight:800!important;
  font-size:clamp(16px,1.5vw,22px)!important; line-height:1.35!important; }


/* Section 2: COURSE BLOCKS (.slb) — slow animations */

/* =========================================================
   COURSE BLOCKS CSS (.slb) — v1.4.3 (SLOW MOTION EDITION)
   Ultra-safe additive: no :root; no global selectors.
   Animations slowed sitewide for course content.
   ========================================================= */

.slb{
  --slb-teal:#0e8296;
  --slb-ink:#222222;
  --slb-ink-muted:#475467;
  --slb-bg:#f5f8f9;
  --slb-card:#ffffff;
  --slb-border:#e2eef0;
  --slb-r-lg:16px;
  --slb-r-sm:10px;
  --slb-sh-1:0 4px 12px rgba(0,0,0,0.15);
  --slb-sh-sm:0 2px 8px rgba(0,0,0,0.08);
  --slb-sh-lg:0 8px 18px rgba(0,0,0,0.18);

  /* Slower timings */
  --slb-ease:cubic-bezier(.22,.61,.36,1);
  --slb-fast:250ms;
  --slb-base:700ms;  /* was 260ms */
  --slb-slow:1000ms; /* was 500ms */

  --slb-space:16px;
  --slb-space-lg:36px;

  --slb-hero-angle:110deg;
  --slb-hero-split:58%;
  --slb-hero-left:var(--slb-teal);
  --slb-hero-right:var(--slb-card);
}

/* Typography — only inside .slb */
.slb h1,.slb h2,.slb h3,.slb h4{
  font-family: Montserrat, Arial, Helvetica, sans-serif;
  color: var(--slb-teal);
  margin:0 0 10px 0;
}
.slb h1{ font-weight:800; line-height:1.30; font-size:clamp(24px,2.5vw,32px); }
.slb h2{ font-weight:800; line-height:1.35; font-size:clamp(20px,2.1vw,26px); }
.slb h3{ font-weight:700; line-height:1.35; font-size:clamp(18px,1.8vw,20px); }

.slb p, .slb li, .slb a, .slb span, .slb div, .slb ol, .slb ul, .slb summary{
  font-family:"Roboto Light New","Roboto Light","Roboto",Arial,Helvetica,sans-serif;
  font-size:16px; line-height:1.65; color:var(--slb-ink);
}

.slb a{ color:var(--slb-teal); text-decoration:underline; text-underline-offset:3px; }
.slb a:hover{ text-decoration-thickness:2px; }
.slb a:focus-visible{
  outline:2px solid #fff; outline-offset:2px;
  box-shadow:0 0 0 3px var(--slb-teal); border-radius:4px;
}
.slb a.link-underline{ position:relative; text-decoration:none; }
.slb a.link-underline::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:100%;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform var(--slb-base) var(--slb-ease);
}
.slb a.link-underline:hover::after,
.slb a.link-underline:focus-visible::after{ transform:scaleX(1); }
.slb strong{ font-weight:700; }

/* Wrapper + Card */
.slb-wrap.teal{
  overflow-x:hidden; padding:16px 1.5%; box-sizing:border-box; background:var(--slb-teal);
}
.slb-card{
  width:100%; max-width:1120px; margin:0 auto; padding:36px; border-radius:var(--slb-r-lg);
  background:var(--slb-card); box-shadow:var(--slb-sh-1); box-sizing:border-box;
  transition:box-shadow var(--slb-base) var(--slb-ease), transform var(--slb-base) var(--slb-ease);
}
.slb-card.hoverable:hover{ box-shadow:var(--slb-sh-lg); transform:translateY(-2px); }

/* Media */
.slb img, .slb video, .slb iframe{ max-width:100%; height:auto; display:block; }
.slb .center{ text-align:center; }
.slb-media{ border-radius:12px; overflow:hidden; box-shadow:var(--slb-sh-sm); background:#000; }
.slb-media.ratio-16x9{ aspect-ratio:16 / 9; }
.slb-media > iframe, .slb-media > video, .slb-media > img{ width:100%; height:100%; border:0; }

/* Infobox */
.slb .infobox{
  background:var(--slb-bg); border:1px solid var(--slb-border); border-radius:12px;
  padding:16px 18px; box-sizing:border-box;
}

/* Buttons */
.slb .btn{
  display:inline-block; font-family:Montserrat, Arial, Helvetica, sans-serif; font-weight:700;
  font-size:14px; line-height:1; padding:12px 16px; border-radius:10px; text-decoration:none; border:0;
  transition:transform var(--slb-fast) var(--slb-ease), box-shadow var(--slb-fast) var(--slb-ease), background var(--slb-fast) var(--slb-ease), color var(--slb-fast) var(--slb-ease);
  will-change:transform;
}
.slb .btn-teal{ background:var(--slb-teal); color:#fff; }
.slb .btn-outline{ background:transparent; color:var(--slb-teal); border:2px solid var(--slb-teal); }
.slb .btn-gradient{ background:linear-gradient(135deg, var(--slb-teal), #11a5be); color:#fff; }
.slb .btn:hover{ transform:translateY(-1px); box-shadow:var(--slb-sh-sm); }
.slb .btn:active{ transform:translateY(0); box-shadow:none; }
.slb .btn:visited{ color:#fff; }
.slb .btn:disabled, .slb .btn[aria-disabled="true"]{ opacity:.6; pointer-events:none; }
.slb .btn:focus-visible{
  outline:2px solid #fff; outline-offset:2px; box-shadow:0 0 0 3px var(--slb-teal);
}

/* Details/Summary accordion */
.slb details{ margin:18px 0 0 0; }
.slb details > summary{
  list-style:none; cursor:pointer; font-family:Montserrat, Arial, Helvetica, sans-serif; font-weight:700;
  font-size:18px; line-height:1.35; color:#fff; background:var(--slb-teal);
  padding:12px 14px; border-radius:10px; user-select:none; position:relative; transition:background var(--slb-fast) var(--slb-ease);
}
.slb details > summary:hover{ background:#0b6d7d; }
.slb details > summary::after{ content:" +"; position:absolute; right:12px; top:50%; transform:translateY(-50%); }
.slb details[open] > summary::after{ content:" –"; }
.slb details > .details-content{
  overflow:hidden; max-height:0; opacity:0; transform:translateY(-4px);
  transition:max-height var(--slb-slow) var(--slb-ease), opacity var(--slb-base) var(--slb-ease), transform var(--slb-base) var(--slb-ease);
  background:var(--slb-bg); border:1px solid var(--slb-border); border-radius:12px; padding:0 18px; box-sizing:border-box;
}
.slb details[open] > .details-content{ max-height:1200px; opacity:1; transform:translateY(0); padding:16px 18px; }

/* Utilities */
.slb .stack > * + *{ margin-top:var(--slb-space); }
.slb .stack-lg > * + *{ margin-top:var(--slb-space-lg); }
.slb .spacer{ height:16px; }
.slb .spacer-lg{ height:28px; }
.slb ul, .slb ol{ padding-left:18px; margin:0 0 10px 0; }
.slb li{ margin:6px 0; }
.slb hr{ border:0; height:1px; background:var(--slb-border); margin:16px 0; }

/* Reveal-on-scroll (slower defaults) */
.slb .slb-animate{
  --a-distance:16px;
  --a-delay:0ms;
  --a-dur:var(--slb-base);
  opacity:0;
  transform:translateY(var(--a-distance));
  transition:
    opacity var(--a-dur) var(--slb-ease) var(--a-delay),
    transform var(--a-dur) var(--slb-ease) var(--a-delay);
  will-change:transform, opacity;
}
.slb .in-view{ opacity:1 !important; transform:none !important; }
.slb .slb-animate[data-anim="fade-in"]{ transform:none; }
.slb .slb-animate[data-anim="fade-up"]{ transform:translateY(var(--a-distance)); }
.slb .slb-animate[data-anim="fade-down"]{ transform:translateY(calc(var(--a-distance) * -1)); }
.slb .slb-animate[data-anim="slide-left"]{ transform:translateX(var(--a-distance)); }
.slb .slb-animate[data-anim="slide-right"]{ transform:translateX(calc(var(--a-distance) * -1)); }
.slb .slb-animate[data-anim="zoom-in"]{ transform:scale(.96); }

/* Stagger spacing slowed */
.slb .slb-stagger > *{ --stagger-step:120ms; } /* was 60ms */
.slb .slb-stagger > *:nth-child(1){ transition-delay:0ms; }
.slb .slb-stagger > *:nth-child(2){ transition-delay:var(--stagger-step); }
.slb .slb-stagger > *:nth-child(3){ transition-delay:calc(var(--stagger-step) * 2); }
.slb .slb-stagger > *:nth-child(4){ transition-delay:calc(var(--stagger-step) * 3); }
.slb .slb-stagger > *:nth-child(5){ transition-delay:calc(var(--stagger-step) * 4); }
.slb .slb-stagger > *:nth-child(6){ transition-delay:calc(var(--stagger-step) * 5); }

/* Diagonal hero (course block variant) */
.slb-hero{ box-sizing:border-box; padding:28px 1.5%; overflow-x:hidden; }
.slb-hero--diag{
  background:linear-gradient(var(--slb-hero-angle), var(--slb-hero-left) 0 var(--slb-hero-split), var(--slb-hero-right) var(--slb-hero-split) 100%);
}
.slb-hero__inner{ width:100%; max-width:1120px; margin:0 auto; display:flex; gap:24px; align-items:center; }
.slb-hero__inner.media-right{ flex-direction:row-reverse; }
.slb-hero__media, .slb-hero__text{ flex:1 1 0; }
.slb-hero__media img, .slb-hero__media video, .slb-hero__media iframe{
  width:100%; height:auto; display:block; border-radius:12px; box-shadow:var(--slb-sh-sm);
}
.slb-hero .on-teal h1,
.slb-hero .on-teal h2,
.slb-hero .on-teal h3,
.slb-hero .on-teal p,
.slb-hero .on-teal li,
.slb-hero .on-teal a{ color:#ffffff; }
.slb-hero .on-teal a{ text-decoration:underline; text-underline-offset:3px; }
.slb-hero .on-teal .btn-outline{ color:#fff; border-color:#fff; }
.slb-hero .on-teal .btn:visited{ color:#fff; }
.slb-hero .slb-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:10px; }

/* Mobile adjustments for blocks only */
@media (max-width:820px){
  .slb-hero__inner{ flex-direction:column; text-align:left; }
  .slb-hero{ padding:20px 1.5%; }
  .slb-hero--diag{ --slb-hero-split:64%; }
}
@media (max-width:480px){
  .slb h1{ line-height:1.32; }
  .slb h2{ line-height:1.36; }
  .slb h3{ line-height:1.38; }
  .slb-card{ padding:28px; }
}

/* === END SITE CSS === */
