/*
 * soved-cases-clean-css-v1
 * Clean styling for /cases/ and single case pages.
 * Data comes from WordPress post fields/meta. This file only controls presentation.
 */

.case-page,
.cases-page{
  background:#f7f9fc;
  color:#0f172a;
}

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

/* Shared text */

.case-title,
.cases-title{
  margin:0;
  color:#0f172a !important;
  -webkit-text-fill-color:#0f172a !important;
  font-size:clamp(38px, 5vw, 62px);
  line-height:1.02;
  letter-spacing:-.055em;
  font-weight:760;
  text-shadow:none !important;
  background:none !important;
}

.case-lead,
.cases-lead{
  margin:22px 0 0;
  max-width:780px;
  color:#475569;
  font-size:19px;
  line-height:1.55;
  letter-spacing:-.015em;
}

.case-kicker,
.cases-kicker,
.cases-card-kicker{
  color:#246bfe;
  font-size:13px;
  line-height:1.2;
  font-weight:760;
  letter-spacing:.03em;
}

/* Single case */

.case-hero{
  padding:98px 0 34px;
  background:linear-gradient(180deg, #f7f9fc 0%, #ffffff 100%);
}

.case-back{
  display:inline-flex;
  margin-bottom:28px;
  color:#64748b;
  text-decoration:none;
  font-size:14px;
  font-weight:650;
}

.case-back:hover{
  color:#246bfe;
}

.case-hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 360px;
  gap:42px;
  align-items:start;
}

.case-kicker{
  margin-bottom:16px;
}

.case-tags,
.cases-card-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.case-tags{
  margin-top:24px;
}

.case-tags span,
.cases-card-tags span{
  display:inline-flex;
  align-items:center;
  min-height:31px;
  padding:0 11px;
  border-radius:999px;
  background:#eef4ff;
  color:#31527c;
  font-size:13px;
  line-height:1;
  font-weight:650;
}

.case-cover{
  overflow:hidden;
  border-radius:24px;
  background:#e9eef7;
  border:1px solid rgba(15,23,42,.08);
}

.case-cover img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:4/3;
  object-fit:cover;
}

.case-summary{
  padding:0 0 24px;
  background:#f7f9fc;
}

.case-summary-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:12px;
}

.case-summary-card{
  min-height:118px;
  padding:18px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:none;
}

.case-summary-card small{
  display:block;
  margin-bottom:9px;
  color:#64748b;
  font-size:10px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.case-summary-card b{
  display:block;
  color:#0f172a;
  font-size:15px;
  line-height:1.36;
  letter-spacing:-.015em;
  font-weight:680;
}

.case-body-shell{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 300px;
  gap:32px;
  align-items:start;
  padding:34px 0 72px;
}

.case-content-card{
  padding:0;
  background:transparent;
}

.case-content-card :where(h2,h3){
  margin:34px 0 14px;
  color:#0f172a;
  line-height:1.12;
  letter-spacing:-.04em;
}

.case-content-card h2{
  font-size:32px;
}

.case-content-card h3{
  font-size:24px;
}

.case-content-card :where(p,li){
  max-width:760px;
  color:#334155;
  font-size:18px;
  line-height:1.72;
  letter-spacing:-.01em;
}

.case-content-card p:first-child{
  margin-top:0;
}

.case-content-card ul,
.case-content-card ol{
  padding-left:1.25em;
}

.case-content-card a{
  color:#246bfe;
  text-decoration:none;
  font-weight:680;
}

.case-content-card a:hover{
  text-decoration:underline;
}

.case-content-card figure{
  margin:28px 0;
}

.case-content-card img{
  max-width:100%;
  height:auto;
  border-radius:22px;
}

.case-aside{
  position:sticky;
  top:92px;
  padding:22px;
  border-radius:24px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:none;
}

.case-aside h3{
  margin:0 0 12px;
  color:#0f172a;
  font-size:20px;
  line-height:1.15;
  letter-spacing:-.035em;
}

.case-aside p{
  margin:0;
  color:#475569;
  font-size:15px;
  line-height:1.58;
}

.case-aside-note{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(15,23,42,.08);
}

.case-aside-note small{
  display:block;
  margin-bottom:7px;
  color:#64748b;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.case-aside-note b{
  display:block;
  color:#0f172a;
  font-size:15px;
  line-height:1.45;
  font-weight:680;
}

.case-cta{
  display:grid;
  gap:10px;
  margin-top:22px;
}

.case-cta a{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 16px;
  border-radius:999px;
  text-decoration:none;
  font-size:14px;
  font-weight:740;
}

.case-cta .primary{
  background:#246bfe;
  color:#fff;
}

.case-cta .secondary{
  background:#f1f5f9;
  color:#334155;
}

/* Cases index */

.cases-page{
  min-height:100vh;
}

.cases-hero{
  padding:98px 0 40px;
  background:linear-gradient(180deg, #f7f9fc 0%, #ffffff 100%);
}

.cases-kicker{
  margin-bottom:16px;
}

.cases-grid-section{
  padding:0 0 74px;
  background:#fff;
}

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

.cases-card{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  min-height:100%;
  border-radius:26px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  color:#0f172a;
  text-decoration:none;
  box-shadow:none;
  transition:border-color .18s ease, transform .18s ease;
}

.cases-card:hover{
  transform:translateY(-2px);
  border-color:rgba(36,107,254,.24);
}

.cases-card-image{
  overflow:hidden;
  background:#e9eef7;
  border-bottom:1px solid rgba(15,23,42,.06);
}

.cases-card-image img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:16/10;
  object-fit:cover;
}

.cases-card-body{
  display:flex;
  flex-direction:column;
  flex:1;
  padding:22px;
}

.cases-card-kicker{
  margin-bottom:12px;
}

.cases-card h2{
  margin:0;
  color:#0f172a;
  font-size:24px;
  line-height:1.1;
  letter-spacing:-.04em;
}

.cases-card p{
  margin:14px 0 0;
  color:#475569;
  font-size:15px;
  line-height:1.55;
}

.cases-card-meta{
  display:none !important;
}

.cases-card-tags{
  margin-top:18px;
  gap:7px;
}

.cases-card-more{
  margin-top:auto;
  padding-top:22px;
  color:#246bfe;
  font-size:14px;
  font-weight:760;
}

.cases-empty{
  padding:28px;
  border-radius:24px;
  background:#f8fafc;
  border:1px solid rgba(15,23,42,.08);
  color:#475569;
}

/* Responsive */

@media(max-width:980px){
  .case-hero-grid,
  .case-body-shell{
    grid-template-columns:1fr;
  }

  .case-summary-grid{
    grid-template-columns:repeat(2, 1fr);
  }

  .case-cover{
    max-width:520px;
  }

  .case-aside{
    position:relative;
    top:auto;
  }

  .cases-grid{
    grid-template-columns:1fr;
  }
}

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

  .case-hero,
  .cases-hero{
    padding-top:82px;
    padding-bottom:26px;
  }

  .case-title,
  .cases-title{
    font-size:32px !important;
    line-height:1.12;
    letter-spacing:-.04em;
  }

  .case-lead,
  .cases-lead{
    margin-top:18px;
    font-size:17px;
    line-height:1.52;
  }

  .case-hero-grid{
    gap:26px;
  }

  .case-summary{
    padding-bottom:14px;
  }

  .case-summary-grid{
    grid-template-columns:1fr;
    gap:8px;
  }

  .case-summary-card{
    min-height:0;
    padding:14px 16px;
    border-radius:18px;
  }

  .case-summary-card b{
    font-size:15px;
  }

  .case-body-shell{
    gap:24px;
    padding-top:24px;
    padding-bottom:56px;
  }

  .case-content-card :where(p,li){
    max-width:none;
    font-size:16px;
    line-height:1.68;
  }

  .case-content-card h2{
    font-size:28px;
  }

  .case-aside{
    padding:18px;
    border-radius:20px;
  }

  .cases-grid-section{
    padding-bottom:54px;
  }

  .cases-grid{
    gap:16px;
  }

  .cases-card{
    border-radius:22px;
  }

  .cases-card-image img{
    aspect-ratio:16/9;
  }

  .cases-card-body{
    padding:18px;
  }

  .cases-card h2{
    font-size:22px;
    line-height:1.14;
  }

  .cases-card p{
    font-size:15px;
    line-height:1.5;
  }

  .cases-card-tags span{
    min-height:29px;
    font-size:12px;
  }
}
