/* ON INC. Cases v3 — editorial premium redesign */
:root{
  --case-blue:#2f55d4;
  --case-blue-dark:#1f3f9d;
  --case-ink:#0f172a;
  --case-text:#334155;
  --case-muted:#64748b;
  --case-soft:#f6f8fc;
  --case-line:rgba(15,23,42,.10);
  --case-line-strong:rgba(15,23,42,.16);
  --case-card:#fff;
  --case-shadow:0 18px 54px rgba(15,23,42,.08);
  --case-shadow-hover:0 28px 82px rgba(15,23,42,.13);
}

body.on-cases-page{
  background:#fff;
  color:var(--case-ink);
}

.on-cases-shell{
  overflow:hidden;
  background:
    radial-gradient(720px 420px at 8% 0%, rgba(47,85,212,.10), transparent 60%),
    linear-gradient(180deg,#f8fbff 0%,#fff 270px,#fff 100%);
}

.on-cases-wrap{
  width:min(1210px, calc(100% - 40px));
  margin:0 auto;
}

.on-cases-masthead{
  position:relative;
  padding:44px 0 30px;
  border-bottom:1px solid rgba(15,23,42,.06);
}

.on-cases-masthead:after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(47,85,212,.35),transparent);
  pointer-events:none;
}

.on-case-breadcrumb{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  color:#94a3b8;
  font-size:14px;
  font-weight:750;
}

.on-case-breadcrumb--masthead{
  margin-bottom:28px;
}

.on-case-breadcrumb a{
  color:#64748b;
  text-decoration:none!important;
  transition:color .18s ease;
}

.on-case-breadcrumb a:hover{
  color:var(--case-blue);
}

.on-cases-masthead__grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:42px;
  align-items:end;
}

.on-cases-masthead__content{
  max-width:870px;
}

.on-cases-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--case-blue-dark);
  font-size:12px;
  line-height:1;
  font-weight:950;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.on-cases-kicker:before{
  content:"";
  width:32px;
  height:1px;
  background:linear-gradient(90deg,var(--case-blue),rgba(47,85,212,.08));
}

.on-cases-title{
  margin:18px 0 0;
  max-width:930px;
  color:var(--case-ink);
  font-size:clamp(40px,5.3vw,72px);
  line-height:1.02;
  letter-spacing:-.055em;
  font-weight:950;
}

.on-cases-lead{
  max-width:780px;
  margin:22px 0 0;
  color:var(--case-muted);
  font-size:18px;
  line-height:1.75;
  font-weight:560;
}

.on-cases-note-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  padding:26px;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 18px 50px rgba(47,85,212,.08);
  backdrop-filter:blur(16px);
}

.on-cases-note-card:before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  background:linear-gradient(90deg,var(--case-blue),#8ab4ff,transparent);
}

.on-cases-note-card span{
  display:block;
  color:#94a3b8;
  font-size:12px;
  font-weight:950;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.on-cases-note-card strong{
  display:block;
  margin-top:12px;
  color:var(--case-ink);
  font-size:26px;
  line-height:1.1;
  letter-spacing:-.035em;
  font-weight:950;
}

.on-cases-note-card p{
  margin:14px 0 0;
  color:var(--case-muted);
  font-size:14px;
  line-height:1.7;
  font-weight:600;
}

.on-cases-mini-stats{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:30px;
}

.on-cases-mini-stats span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:40px;
  padding:0 15px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  color:#64748b;
  font-size:13px;
  font-weight:800;
  box-shadow:0 10px 28px rgba(15,23,42,.04);
}

.on-cases-mini-stats strong{
  color:var(--case-ink);
  font-weight:950;
}

.on-cases-section{
  padding:48px 0 82px;
}

.on-cases-section--article{
  padding-top:38px;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
}

.on-cases-toolbar{
  display:flex;
  gap:22px;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:24px;
}

.on-cases-toolbar--compact{
  margin-bottom:20px;
}

.on-cases-eyebrow{
  display:block;
  margin-bottom:8px;
  color:var(--case-blue);
  font-size:12px;
  font-weight:950;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.on-cases-h2{
  margin:0;
  color:var(--case-ink);
  font-size:clamp(28px,3.2vw,44px);
  line-height:1.08;
  letter-spacing:-.04em;
  font-weight:950;
}

.on-cases-filter{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 28px;
}

.on-cases-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:42px;
  padding:0 15px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  color:#475569;
  text-decoration:none!important;
  font-size:14px;
  font-weight:850;
  transition:all .22s ease;
}

.on-cases-chip span{
  display:inline-grid;
  min-width:24px;
  height:24px;
  place-items:center;
  border-radius:999px;
  background:#f1f5f9;
  color:#64748b;
  font-size:12px;
}

.on-cases-chip:hover{
  color:var(--case-blue-dark);
  border-color:rgba(47,85,212,.22);
  transform:translateY(-1px);
}

.on-cases-chip.is-active{
  color:#fff;
  border-color:transparent;
  background:linear-gradient(135deg,var(--case-blue),var(--case-blue-dark));
  box-shadow:0 14px 34px rgba(47,85,212,.24);
}

.on-cases-chip.is-active span{
  color:#fff;
  background:rgba(255,255,255,.18);
}

.on-cases-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 20px;
  border-radius:16px;
  text-decoration:none!important;
  border:1px solid transparent;
  font-size:14px;
  font-weight:900;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}

.on-cases-btn:hover{
  transform:translateY(-2px);
}

.on-cases-btn--primary{
  color:#fff;
  background:linear-gradient(135deg,var(--case-blue),var(--case-blue-dark));
  box-shadow:0 18px 42px rgba(47,85,212,.25);
}

.on-cases-btn--primary:hover{
  color:#fff;
  box-shadow:0 24px 58px rgba(47,85,212,.32);
}

.on-cases-btn--ghost{
  color:#172554;
  background:#fff;
  border-color:rgba(15,23,42,.10);
  box-shadow:0 12px 28px rgba(15,23,42,.05);
}

.on-cases-btn--ghost:hover{
  color:var(--case-blue-dark);
  border-color:rgba(47,85,212,.22);
}

.on-cases-btn--light{
  color:#172554;
  background:#fff;
  border-color:rgba(255,255,255,.42);
}

.on-case-spotlight{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,.98fr) minmax(0,1.02fr);
  overflow:hidden;
  min-height:430px;
  margin-bottom:22px;
  border-radius:34px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:var(--case-shadow);
  text-decoration:none!important;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.on-case-spotlight:hover{
  transform:translateY(-4px);
  border-color:rgba(47,85,212,.18);
  box-shadow:var(--case-shadow-hover);
}

.on-case-spotlight__media,
.on-case-card__media{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 28% 20%, rgba(255,255,255,.25), transparent 24%),
    linear-gradient(135deg,#172554,#2f55d4 55%,#93b3ff);
}

.on-case-spotlight__media:after,
.on-case-card__media:after,
.on-case-cover-wide:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 54%,rgba(15,23,42,.18));
  pointer-events:none;
}

.on-case-spotlight__media img,
.on-case-card__media img,
.on-case-cover-wide img,
.on-case-gallery__item img,
.on-case-recent__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.on-case-spotlight__media img,
.on-case-card__media img{
  transition:transform .55s ease;
}

.on-case-spotlight:hover .on-case-spotlight__media img,
.on-case-card:hover .on-case-card__media img{
  transform:scale(1.045);
}

.on-case-card__placeholder{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:rgba(255,255,255,.92);
  font-size:13px;
  font-weight:950;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.on-case-spotlight__body{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:46px;
}

.on-case-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:16px;
}

.on-case-card__meta span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 11px;
  border-radius:999px;
  background:#f1f5f9;
  color:#64748b;
  font-size:12px;
  font-weight:850;
}

.on-case-spotlight h3{
  margin:0;
  color:var(--case-ink);
  font-size:clamp(32px,4vw,52px);
  line-height:1.02;
  letter-spacing:-.05em;
  font-weight:950;
}

.on-case-spotlight p{
  margin:18px 0 0;
  color:var(--case-muted);
  font-size:16px;
  line-height:1.75;
  font-weight:590;
}

.on-case-readmore{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:auto;
  padding-top:24px;
  color:var(--case-blue);
  font-size:15px;
  font-weight:950;
}

.on-case-readmore i{
  display:grid;
  width:34px;
  height:34px;
  place-items:center;
  border-radius:12px;
  color:#fff;
  background:var(--case-blue);
  font-style:normal;
  transition:transform .2s ease;
}

.on-case-card:hover .on-case-readmore i,
.on-case-spotlight:hover .on-case-readmore i{
  transform:translateX(3px);
}

.on-cases-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}

.on-case-card{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  min-height:100%;
  border-radius:28px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 14px 38px rgba(15,23,42,.06);
  text-decoration:none!important;
  transition:transform .23s ease, box-shadow .23s ease, border-color .23s ease;
}

.on-case-card:hover{
  transform:translateY(-5px);
  border-color:rgba(47,85,212,.18);
  box-shadow:0 24px 64px rgba(15,23,42,.11);
}

.on-case-card__media{
  min-height:220px;
}

.on-case-card__body{
  display:flex;
  flex:1;
  flex-direction:column;
  padding:23px;
}

.on-case-card__title{
  margin:0;
  color:var(--case-ink);
  font-size:22px;
  line-height:1.2;
  letter-spacing:-.032em;
  font-weight:950;
}

.on-case-card__text{
  margin:13px 0 0;
  color:var(--case-muted);
  font-size:14px;
  line-height:1.7;
  font-weight:570;
}

.on-cases-empty{
  grid-column:1 / -1;
  border-radius:28px;
  padding:34px;
  background:#fff;
  border:1px dashed rgba(47,85,212,.28);
  color:#475569;
  text-align:center;
  font-size:16px;
  line-height:1.65;
  font-weight:750;
}

.on-cases-pagination{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  margin-top:36px;
}

.on-cases-page-link{
  display:inline-grid;
  min-width:44px;
  height:44px;
  place-items:center;
  border-radius:15px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  color:#334155;
  text-decoration:none!important;
  box-shadow:0 10px 24px rgba(15,23,42,.05);
  font-weight:950;
}

.on-cases-page-link:hover{
  color:var(--case-blue);
  border-color:rgba(47,85,212,.22);
}

.on-cases-page-link.is-active{
  color:#fff;
  border-color:transparent;
  background:linear-gradient(135deg,var(--case-blue),var(--case-blue-dark));
}

.on-cases-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  margin-top:54px;
  padding:28px;
  border-radius:30px;
  background:linear-gradient(135deg,#f8fbff,#fff);
  border:1px solid rgba(47,85,212,.14);
  box-shadow:0 18px 52px rgba(47,85,212,.08);
}

.on-cases-cta small{
  display:block;
  margin-bottom:8px;
  color:var(--case-blue);
  font-size:12px;
  font-weight:950;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.on-cases-cta h3{
  margin:0;
  max-width:780px;
  color:var(--case-ink);
  font-size:clamp(24px,3vw,34px);
  line-height:1.12;
  letter-spacing:-.035em;
  font-weight:950;
}

/* Detail page */
.on-case-article-head{
  padding:42px 0 0;
  background:
    radial-gradient(680px 340px at 12% 0%, rgba(47,85,212,.11), transparent 60%),
    linear-gradient(180deg,#f8fbff 0%, #fff 100%);
}

.on-case-article-head__grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:44px;
  align-items:end;
  margin-top:28px;
}

.on-case-article-title{
  margin:18px 0 0;
  max-width:910px;
  color:var(--case-ink);
  font-size:clamp(38px,5vw,68px);
  line-height:1.02;
  letter-spacing:-.055em;
  font-weight:950;
}

.on-case-article-lead{
  max-width:820px;
  margin:20px 0 0;
  color:var(--case-muted);
  font-size:18px;
  line-height:1.75;
  font-weight:580;
}

.on-case-passport{
  overflow:hidden;
  border-radius:26px;
  padding:24px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 16px 44px rgba(15,23,42,.07);
}

.on-case-passport span{
  display:block;
  color:#94a3b8;
  font-size:12px;
  font-weight:950;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.on-case-passport strong{
  display:block;
  margin-top:12px;
  color:var(--case-ink);
  font-size:30px;
  line-height:1;
  letter-spacing:-.04em;
  font-weight:950;
}

.on-case-passport p{
  margin:12px 0 0;
  color:var(--case-muted);
  font-size:14px;
  line-height:1.6;
  font-weight:650;
}

.on-case-passport a{
  display:inline-flex;
  margin-top:16px;
  color:var(--case-blue);
  text-decoration:none!important;
  font-size:14px;
  font-weight:950;
}

.on-case-cover-wide{
  position:relative;
  overflow:hidden;
  min-height:420px;
  margin-top:34px;
  border-radius:34px;
  background:linear-gradient(135deg,#172554,#2f55d4 58%,#93b3ff);
  box-shadow:0 24px 70px rgba(15,23,42,.14);
}

.on-case-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:30px;
  align-items:start;
}

.on-case-main-card{
  overflow:hidden;
  border-radius:32px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 18px 54px rgba(15,23,42,.07);
}

.on-case-summary{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  border-bottom:1px solid rgba(15,23,42,.08);
}

.on-case-summary__item{
  padding:24px;
  border-right:1px solid rgba(15,23,42,.08);
}

.on-case-summary__item:last-child{
  border-right:0;
}

.on-case-summary__item small{
  display:block;
  color:var(--case-blue);
  font-size:12px;
  font-weight:950;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.on-case-summary__item strong{
  display:block;
  margin-top:9px;
  color:var(--case-ink);
  font-size:19px;
  line-height:1.2;
  letter-spacing:-.025em;
  font-weight:950;
}

.on-case-summary__item span{
  display:block;
  margin-top:9px;
  color:var(--case-muted);
  font-size:13px;
  line-height:1.6;
  font-weight:600;
}

.on-case-prose{
  padding:34px;
  color:#263244;
  font-size:17px;
  line-height:1.82;
  font-weight:500;
}

.on-case-prose > *:first-child{
  margin-top:0!important;
}

.on-case-prose > *:last-child{
  margin-bottom:0!important;
}

.on-case-prose h2,
.on-case-prose h3,
.on-case-prose h4{
  color:var(--case-ink);
  letter-spacing:-.035em;
  font-weight:950;
}

.on-case-prose h2{
  margin:34px 0 14px;
  font-size:34px;
  line-height:1.14;
}

.on-case-prose h3{
  margin:28px 0 12px;
  font-size:26px;
  line-height:1.18;
}

.on-case-prose p,
.on-case-prose ul,
.on-case-prose ol{
  margin:0 0 18px;
}

.on-case-prose ul,
.on-case-prose ol{
  padding-left:22px;
}

.on-case-prose li{
  margin:8px 0;
}

.on-case-prose a{
  color:var(--case-blue);
  font-weight:800;
  text-decoration:none;
}

.on-case-prose img{
  max-width:100%;
  height:auto;
  border-radius:22px;
  margin:18px 0;
}

.on-case-source{
  margin:0 34px 34px;
  padding:20px 22px;
  border-radius:22px;
  background:#f8fbff;
  border:1px solid rgba(47,85,212,.14);
  color:#475569;
  font-size:15px;
  line-height:1.65;
  font-weight:650;
}

.on-case-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:0 34px 34px;
}

.on-case-tag{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:0 13px;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  text-decoration:none!important;
  font-size:13px;
  font-weight:850;
  transition:all .2s ease;
}

.on-case-tag:hover{
  color:#fff;
  background:var(--case-blue);
}

.on-case-sidebar{
  position:sticky;
  top:96px;
  display:grid;
  gap:16px;
}

.on-case-side-card{
  overflow:hidden;
  border-radius:26px;
  padding:22px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 14px 40px rgba(15,23,42,.06);
}

.on-case-side-card--blue{
  color:#fff;
  border-color:transparent;
  background:
    radial-gradient(circle at 20% 0%, rgba(255,255,255,.20), transparent 34%),
    linear-gradient(135deg,#172554,#2f55d4);
  box-shadow:0 22px 58px rgba(47,85,212,.24);
}

.on-case-side-card--blue > span{
  display:block;
  color:rgba(255,255,255,.66);
  font-size:12px;
  font-weight:950;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.on-case-side-card--blue h3,
.on-case-side-title{
  margin:0;
  color:inherit;
  font-size:21px;
  line-height:1.16;
  letter-spacing:-.03em;
  font-weight:950;
}

.on-case-side-card--blue h3{
  margin-top:10px;
  font-size:26px;
}

.on-case-side-card--blue p{
  margin:13px 0 18px;
  color:rgba(255,255,255,.76);
  font-size:14px;
  line-height:1.65;
  font-weight:630;
}

.on-case-side-list{
  display:grid;
  gap:8px;
  margin:16px 0 0;
  padding:0;
  list-style:none;
}

.on-case-side-list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:44px;
  padding:0 13px;
  border-radius:15px;
  background:#f8fafc;
  color:#334155;
  text-decoration:none!important;
  font-size:14px;
  font-weight:820;
  transition:all .2s ease;
}

.on-case-side-list a:hover{
  color:var(--case-blue);
  background:#eef3ff;
}

.on-case-side-list strong{
  color:inherit;
  font-size:13px;
  font-weight:950;
}

.on-case-recent{
  display:grid;
  gap:12px;
  margin-top:16px;
}

.on-case-recent a{
  display:grid;
  grid-template-columns:64px minmax(0,1fr);
  gap:12px;
  align-items:center;
  color:var(--case-ink);
  text-decoration:none!important;
}

.on-case-recent__thumb{
  display:block;
  overflow:hidden;
  width:64px;
  height:64px;
  border-radius:18px;
  background:linear-gradient(135deg,#172554,#2f55d4);
}

.on-case-recent strong{
  display:block;
  color:var(--case-ink);
  font-size:14px;
  line-height:1.28;
  font-weight:900;
}

.on-case-recent span span{
  display:block;
  margin-top:4px;
  color:#94a3b8;
  font-size:12px;
  font-weight:800;
}

.on-case-gallery,
.on-case-related{
  margin-top:42px;
}

.on-case-gallery__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}

.on-case-gallery__item{
  position:relative;
  overflow:hidden;
  min-height:250px;
  border-radius:28px;
  background:#e2e8f0;
  box-shadow:0 14px 38px rgba(15,23,42,.08);
}

.on-case-related__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}

@media (max-width: 1100px){
  .on-cases-masthead__grid,
  .on-case-article-head__grid,
  .on-case-layout{
    grid-template-columns:1fr;
  }

  .on-cases-note-card,
  .on-case-passport{
    max-width:560px;
  }

  .on-case-sidebar{
    position:static;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .on-case-side-card--blue{
    grid-column:1 / -1;
  }
}

@media (max-width: 900px){
  .on-case-spotlight{
    grid-template-columns:1fr;
  }

  .on-case-spotlight__media{
    min-height:320px;
  }

  .on-cases-grid,
  .on-case-gallery__grid,
  .on-case-related__grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .on-case-summary{
    grid-template-columns:1fr;
  }

  .on-case-summary__item{
    border-right:0;
    border-bottom:1px solid rgba(15,23,42,.08);
  }

  .on-case-summary__item:last-child{
    border-bottom:0;
  }

  .on-cases-toolbar,
  .on-cases-cta{
    align-items:flex-start;
    flex-direction:column;
  }
}

@media (max-width: 640px){
  .on-cases-wrap{
    width:min(100% - 28px, 1210px);
  }

  .on-cases-masthead,
  .on-case-article-head{
    padding-top:30px;
  }

  .on-cases-title,
  .on-case-article-title{
    font-size:38px;
    letter-spacing:-.045em;
  }

  .on-cases-lead,
  .on-case-article-lead{
    font-size:16px;
  }

  .on-case-spotlight__body,
  .on-case-prose{
    padding:24px;
  }

  .on-case-cover-wide{
    min-height:280px;
    border-radius:26px;
  }

  .on-cases-grid,
  .on-case-gallery__grid,
  .on-case-related__grid,
  .on-case-sidebar{
    grid-template-columns:1fr;
  }

  .on-case-card__media{
    min-height:210px;
  }

  .on-cases-section{
    padding-bottom:58px;
  }
}
