/* ============================================================
   HumanSide — For Educators page components
   Built on humanside.css + humanside-sections.css tokens.
   ============================================================ */

/* ---------------- HERO character ---------------- */
.edu-hero{ position:relative; overflow:hidden; padding:clamp(8rem,14vw,11rem) 0 clamp(3rem,6vw,4.5rem); }
.edu-hero .wrap{ position:relative; z-index:5; }
.edu-hero-grid{ display:grid; grid-template-columns:1.25fr .75fr; gap:2rem; align-items:center; }
.edu-hero h1{ font-weight:700; line-height:1; letter-spacing:-.03em; font-size:clamp(2.5rem,5.4vw,4.4rem); max-width:15ch; margin-top:1rem; }
.edu-hero .lead{ margin-top:1.3rem; max-width:48ch; }
.edu-hero-trust{ display:flex; gap:1.6rem; flex-wrap:wrap; margin-top:1.9rem; }
.edu-hero-trust .t b{ display:block; font-size:1.9rem; font-weight:700; letter-spacing:-.02em; line-height:1; }
.edu-hero-trust .t span{ font-size:.85rem; color:var(--ink-soft); }
.edu-hero-trust .t .serif{ color:var(--orange-deep); font-style:italic; }
.edu-figure{ position:relative; justify-self:center; align-self:end; height:min(46vh,420px); }
.edu-figure video{ height:100%; width:auto; filter:drop-shadow(0 28px 38px rgba(22,21,46,.2)); }
.edu-figure .bubble{ position:absolute; top:6%; right:64%; white-space:nowrap; }
@media (max-width:880px){ .edu-hero-grid{ grid-template-columns:1fr; } .edu-figure{ display:none; } }

/* ---------------- WHY IT WORKS (hover-reveal) ---------------- */
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
.why-card{
  position:relative; background:var(--white); border-radius:var(--r-md);
  padding:1.7rem 1.6rem; overflow:hidden; cursor:default;
  box-shadow:0 1px 0 rgba(22,21,46,.05);
  transition:transform .4s var(--ease-elastic), box-shadow .4s;
}
.why-card:hover{ transform:translateY(-6px); box-shadow:0 26px 50px -28px rgba(22,21,46,.4); }
.why-card .swatch{ position:absolute; right:-26px; top:-26px; width:84px;height:84px;border-radius:50%; background:var(--blue-soft); opacity:.65; transition:transform .5s var(--ease-elastic); }
.why-card:hover .swatch{ transform:scale(1.25); }
.why-card:nth-child(3n+2) .swatch{ background:var(--orange-soft); }
.why-card:nth-child(3n) .swatch{ background:var(--green-soft); }
.why-card .num{ font-family:var(--font-serif); font-style:italic; font-weight:500; font-size:2.1rem; line-height:1; color:var(--blue); position:relative; z-index:1; }
.why-card:nth-child(3n+2) .num{ color:var(--orange-deep); }
.why-card:nth-child(3n) .num{ color:var(--green); }
.why-card h4{ font-size:1.2rem; font-weight:700; letter-spacing:-.02em; margin:.7rem 0 0; position:relative; z-index:1; }
.why-card .why-detail{
  max-height:0; opacity:0; overflow:hidden;
  transition:max-height .5s var(--ease-out), opacity .4s, margin .4s;
}
.why-card .why-detail p{ font-size:.93rem; color:var(--ink-soft); line-height:1.5; margin-top:.6rem; }
.why-card:hover .why-detail, .why-card:focus-within .why-detail{ max-height:200px; opacity:1; }
.why-card .hint{ font-size:.78rem; font-weight:600; color:var(--blue-deep); margin-top:.7rem; opacity:.7; transition:opacity .3s; }
.why-card:hover .hint{ opacity:0; max-height:0; }
@media (hover:none){
  .why-card .why-detail{ max-height:200px; opacity:1; }
  .why-card .hint{ display:none; }
}
@media (max-width:880px){ .why-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .why-grid{ grid-template-columns:1fr; } }

/* ---------------- FLOW STEPPER ---------------- */
.flow{ position:relative; }
.flow-track{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; position:relative; }
.flow-track::before{ content:""; position:absolute; left:8%; right:8%; top:30px; height:3px; background:rgba(22,21,46,.12); border-radius:2px; z-index:0; }
.flow-prog{ position:absolute; left:8%; top:30px; height:3px; background:var(--orange); border-radius:2px; z-index:1; transition:width .5s var(--ease-out); }
.flow-step{ position:relative; z-index:2; text-align:center; background:none; display:flex; flex-direction:column; align-items:center; gap:.7rem; padding:0 .4rem; }
.flow-step .dot{
  width:60px;height:60px;border-radius:50%; background:var(--white);
  box-shadow:inset 0 0 0 2px rgba(22,21,46,.12);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-serif); font-style:italic; font-weight:500; font-size:1.5rem; color:var(--ink-soft);
  transition:all .4s var(--ease-elastic);
}
.flow-step .lbl{ font-size:.98rem; font-weight:700; letter-spacing:-.01em; color:var(--ink-2); transition:color .3s; }
.flow-step.active .dot{ background:var(--orange); color:var(--ink); box-shadow:0 12px 24px -10px rgba(251,157,89,.9); transform:scale(1.08); }
.flow-step.active .lbl{ color:var(--ink); }
.flow-step:hover .dot{ box-shadow:inset 0 0 0 2px var(--orange); }
.flow-detail{
  display:none; margin-top:2.4rem; background:var(--white); border-radius:var(--r-md);
  padding:clamp(1.6rem,3vw,2.4rem); box-shadow:0 24px 50px -34px rgba(22,21,46,.4);
  grid-template-columns:auto 1fr; gap:1.6rem; align-items:center;
}
.flow-detail.active{ display:grid; animation:fadeUp .5s var(--ease-out); }
.flow-detail .big{ font-family:var(--font-serif); font-style:italic; font-weight:500; font-size:clamp(3rem,7vw,5rem); line-height:1; color:var(--orange); }
.flow-detail h4{ font-size:1.4rem; font-weight:700; letter-spacing:-.02em; margin-bottom:.5rem; }
.flow-detail p{ font-size:1.02rem; color:var(--ink-2); line-height:1.6; max-width:60ch; }
.flow-detail .tag{ display:inline-block; margin-top:.9rem; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }
@media (max-width:760px){
  .flow-track{ grid-template-columns:1fr 1fr; gap:1.4rem 1rem; }
  .flow-track::before, .flow-prog{ display:none; }
  .flow-detail{ grid-template-columns:1fr; text-align:center; }
}

/* ---------------- USE TABS ---------------- */
.usetabs{ display:grid; grid-template-columns:.8fr 1.2fr; gap:1.6rem; align-items:start; }
.tabrail{ display:flex; flex-direction:column; gap:.5rem; }
.tabrail button{
  text-align:left; padding:1rem 1.2rem; border-radius:var(--r-sm);
  font-size:1rem; font-weight:600; color:var(--ink-2);
  background:var(--white); box-shadow:inset 0 0 0 1.5px rgba(22,21,46,.08);
  transition:all .3s var(--ease-out); display:flex; align-items:center; gap:.7rem;
}
.tabrail button .n{ font-family:var(--font-serif); font-style:italic; color:var(--blue); font-size:1.1rem; }
.tabrail button:hover{ box-shadow:inset 0 0 0 1.5px var(--blue-tint); }
.tabrail button.active{ background:var(--blue); color:var(--white); box-shadow:0 12px 24px -12px rgba(83,127,235,.8); }
.tabrail button.active .n{ color:var(--cream); }
.tabwrap{ position:relative; }
.tabpanel{ display:none; background:var(--white); border-radius:var(--r-md); padding:clamp(1.8rem,3.5vw,2.6rem); box-shadow:0 24px 50px -34px rgba(22,21,46,.4); min-height:240px; }
.tabpanel.active{ display:block; animation:fadeUp .5s var(--ease-out); }
.tabpanel .eyebrow{ margin-bottom:.8rem; }
.tabpanel h4{ font-size:1.6rem; font-weight:700; letter-spacing:-.02em; margin-bottom:.8rem; }
.tabpanel p{ font-size:1.05rem; color:var(--ink-2); line-height:1.65; max-width:52ch; }
.tabpanel .tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.4rem; }
@media (max-width:760px){ .usetabs{ grid-template-columns:1fr; } .tabrail{ flex-direction:row; flex-wrap:wrap; } .tabrail button{ flex:1 1 auto; } }

/* ---------------- COURSE PICKER ---------------- */
.picker-chips{ display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin-bottom:2.2rem; }
.picker-chips button{
  padding:.7rem 1.25rem; border-radius:999px; font-size:.98rem; font-weight:600;
  background:var(--white); color:var(--ink-2); box-shadow:inset 0 0 0 1.5px rgba(22,21,46,.1);
  transition:all .3s var(--ease-out);
}
.picker-chips button:hover{ box-shadow:inset 0 0 0 1.5px var(--orange); }
.picker-chips button.active{ background:var(--ink); color:var(--cream); box-shadow:none; transform:translateY(-2px); }
.picker-panel{ display:none; }
.picker-panel.active{ display:block; animation:fadeUp .5s var(--ease-out); }
.picker-card{
  background:var(--blue); color:var(--cream); border-radius:var(--r-lg);
  padding:clamp(2rem,4vw,3.2rem); display:grid; grid-template-columns:1.1fr .9fr; gap:2.2rem; align-items:center;
}
.picker-card.c-orange{ background:var(--orange); color:var(--ink); }
.picker-card.c-green{ background:var(--green); color:var(--cream); }
.picker-card.c-ink{ background:var(--ink); color:var(--cream); }
.picker-card.c-plum{ background:var(--plum); color:var(--cream); }
.picker-card .pc-eyebrow{ font-size:.82rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; opacity:.8; }
.picker-card h3{ font-size:clamp(1.7rem,3.4vw,2.6rem); font-weight:700; letter-spacing:-.025em; line-height:1.04; margin:.6rem 0 1rem; }
.picker-card p{ font-size:1.05rem; line-height:1.6; opacity:.92; }
.picker-card .maps{ display:flex; flex-direction:column; gap:.7rem; }
.picker-card .maps .m{ display:flex; gap:.7rem; align-items:flex-start; font-size:.96rem; }
.picker-card .maps .m .k{ font-weight:700; opacity:.85; }
.picker-card .chip{
  display:inline-flex; align-items:center; gap:.4rem; font-size:.8rem; font-weight:600;
  padding:.4rem .8rem; border-radius:999px; background:rgba(255,255,255,.18);
}
.picker-card.c-orange .chip{ background:rgba(22,21,46,.12); }
.pc-mapwrap{ background:rgba(255,255,255,.12); border-radius:var(--r-md); padding:1.6rem; }
.picker-card.c-orange .pc-mapwrap{ background:rgba(22,21,46,.08); }
.pc-mapwrap h5{ font-size:.82rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; opacity:.8; margin-bottom:1rem; }
@media (max-width:760px){ .picker-card{ grid-template-columns:1fr; gap:1.6rem; } }

/* ---------------- ACCORDION ---------------- */
.inc-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,4vw,3.5rem); align-items:start; }
.acc{ display:flex; flex-direction:column; gap:.7rem; }
.acc-item{ background:var(--white); border-radius:var(--r-sm); box-shadow:inset 0 0 0 1.5px rgba(22,21,46,.08); overflow:hidden; transition:box-shadow .3s; }
.acc-item.open{ box-shadow:inset 0 0 0 1.5px var(--blue-tint), 0 18px 40px -28px rgba(22,21,46,.4); }
.acc-btn{ width:100%; text-align:left; padding:1.15rem 1.3rem; font-size:1.05rem; font-weight:700; letter-spacing:-.01em; color:var(--ink); display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.acc-btn .ico{ flex-shrink:0; width:26px;height:26px;border-radius:50%; background:var(--blue-soft); color:var(--blue-deep); display:flex; align-items:center; justify-content:center; font-size:1.2rem; font-weight:600; transition:transform .4s var(--ease-elastic), background .3s; }
.acc-item.open .acc-btn .ico{ transform:rotate(45deg); background:var(--orange); color:var(--ink); }
.acc-body{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease-out); }
.acc-body p{ padding:0 1.3rem 1.3rem; font-size:.95rem; color:var(--ink-soft); line-height:1.55; }
.inc-shots{ display:flex; flex-direction:column; gap:1.2rem; }
.inc-shots img{ border-radius:var(--r-md); box-shadow:0 30px 60px -36px rgba(22,21,46,.55); }
.inc-shots img:nth-child(1){ transform:rotate(-1.2deg); }
.inc-shots img:nth-child(2){ transform:rotate(1deg); }
.inc-shots img{ transition:transform .5s var(--ease-elastic); }
.inc-shots img:hover{ transform:rotate(0) scale(1.01); }
@media (max-width:880px){ .inc-grid{ grid-template-columns:1fr; } }

/* ---------------- PRICING ---------------- */
.pricing{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; max-width:920px; margin:0 auto; align-items:stretch; }
.price-card{ background:var(--white); border-radius:var(--r-lg); padding:clamp(2rem,3.5vw,2.8rem); display:flex; flex-direction:column; box-shadow:0 24px 50px -36px rgba(22,21,46,.4); }
.price-card.pilot{ box-shadow:inset 0 0 0 2px var(--green-soft), 0 24px 50px -36px rgba(22,21,46,.35); }
.price-card.dark{ background:var(--ink); color:var(--cream); }
.price-eyebrow{ font-size:.82rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--green); }
.price-card.dark .price-eyebrow{ color:var(--orange); }
.price-card h3{ font-size:1.5rem; font-weight:700; letter-spacing:-.02em; margin:.5rem 0 1rem; }
.price-card.dark h3{ color:var(--cream); }
.price-amt{ font-size:clamp(2.6rem,6vw,3.4rem); font-weight:700; letter-spacing:-.03em; line-height:1; color:var(--green); }
.price-card.dark .price-amt{ color:var(--orange); }
.price-amt small{ font-size:1rem; font-weight:500; color:var(--ink-soft); }
.price-card.dark .price-amt small{ color:rgba(248,245,236,.6); }
.price-tags{ display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; margin:.7rem 0 0; }
.price-note{ font-size:.78rem; color:rgba(248,245,236,.55); }
.price-card .desc{ font-size:.95rem; color:var(--ink-soft); margin:1rem 0 1.2rem; line-height:1.55; }
.price-card.dark .desc{ color:rgba(248,245,236,.72); }
.classpack{ background:rgba(255,255,255,.08); border-radius:var(--r-sm); padding:.85rem 1.1rem; margin-bottom:1.4rem; }
.classpack b{ color:var(--orange); font-size:.92rem; }
.classpack span{ display:block; font-size:.82rem; color:rgba(248,245,236,.6); margin-top:.15rem; }
.price-list{ display:flex; flex-direction:column; gap:.6rem; margin-bottom:1.6rem; }
.price-list li{ display:flex; gap:.6rem; align-items:flex-start; font-size:.93rem; }
.price-list .ck{ flex-shrink:0; color:var(--green); font-weight:700; }
.price-card.dark .price-list li{ color:rgba(248,245,236,.85); }
.price-card.dark .price-list .ck{ color:var(--orange); }
.price-card .btn{ margin-top:auto; width:100%; justify-content:center; }
@media (max-width:680px){ .pricing{ grid-template-columns:1fr; } }
