/* ==============================
   Solutions Page (solutions.css)
   Uses your :root vars from style.css
================================ */

/* HERO */
.solHero{
  position:relative;
  min-height: 70vh;
  display:grid;
  place-items:center;
  overflow:hidden;
  padding: 96px 0 70px;
}

.solHero__bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.62), rgba(0,0,0,.35)),
    url("../assets/images/solutions.jpg") center/cover no-repeat;
  transform: translateZ(0);
}

.solHero__fade{
  position:absolute;
  left:0; right:0; bottom:-1px;
  height: 60px;
  background: linear-gradient(180deg, rgba(31, 32, 32, 0.479), var(--bg));
}

.solHero__inner{ position:relative; z-index:1; }
.solHero__center{
  text-align:center;
  max-width: 920px;
  margin: 0 auto;
}

.solPill{
  display:inline-flex;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(10px);
  color:#fff;
  font-weight: 1000;
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}

.solHero__title{
  margin: 14px 0 10px;
  color:#fff;
  font-weight: 1150;
  letter-spacing: -1px;
  font-size: clamp(34px, 4.2vw, 62px);
  line-height: 1.05;
}

.solGrad{
  background: linear-gradient(90deg, #fff, rgba(255,255,255,.65));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

.solHero__sub{
  margin: 0 auto 18px;
  max-width: 80ch;
  color: rgba(255,255,255,.9);
  font-weight: 650;
  line-height: 1.85;
}

.solHero__actions{
  display:flex;
  gap: 12px;
  justify-content:center;
  flex-wrap:wrap;
}

/* Intro */
.solIntro{ padding: 52px 0 10px; }
.solTitle{
  margin:0;
  color: var(--ink);
  font-size: clamp(24px, 2.6vw, 38px);
  letter-spacing: -.5px;
}
.solLead{
  margin: 12px 0 0;
  color:#334155;
  font-weight: 650;
  line-height: 1.85;
  /* max-width: 92ch; */
}

/* Section */
.solSection{ padding: 56px 0; }
.solHead{ margin-bottom: 14px; }

/* GRID: 5 -> 4 -> 3 -> 2 -> 1 */
.solGrid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 14px;
  margin-top: 14px;
}

/* CARD */
.solCard{
  position:relative;
  overflow:hidden;
  border-radius: calc(var(--r) + 14px);
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(2,6,23,.12);
  box-shadow: var(--shadow2);
  transition: .3s ease;
  display:flex;
  flex-direction:column;
  min-height: 340px;
  will-change: transform;
}

/* Glow + shine */
.solCard::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(520px 220px at 12% 0%, rgba(231,61,84,.18), transparent 60%),
    radial-gradient(520px 220px at 88% 10%, rgba(3,81,148,.16), transparent 58%);
  opacity: 0;
  transition:.28s ease;
  pointer-events:none;
}
.solCard::after{
  content:"";
  position:absolute;
  top:-35%;
  left:-140%;
  width:55%;
  height:170%;
  transform: rotate(18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.75), transparent);
  opacity:0;
  pointer-events:none;
}

.solCard:hover{
  transform: translateY(-10px);
  box-shadow: 0 36px 90px rgba(2,6,23,.14);
  border-color: rgba(231,61,84,.25);
}
.solCard:hover::before{ opacity: 1; }
.solCard:hover::after{
  opacity:1;
  animation: solShine .9s ease;
}
@keyframes solShine{
  0%{ left:-140%; }
  100%{ left:160%; }
}

/* MEDIA IMG */
.solCard__media{
  height: 148px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.05)),
    var(--img) center/cover no-repeat;
  position:relative;
}

/* Body */
.solCard__body{
  padding: 14px 14px 10px;
}
.solCard h3{
  margin: 0 0 8px;
  color: var(--ink);
  font-weight: 1100;
  letter-spacing:-.3px;
  font-size: 1.05rem;
  line-height: 1.25;
}
.solCard p{
  margin:0;
  color:#334155;
  font-weight:650;
  line-height: 1.75;
}

/* Footer */
.solCard__foot{
  margin-top:auto;
  padding: 12px 14px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}

.solChip{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(2,6,23,.12);
  background: rgba(255,255,255,.88);
  box-shadow: var(--shadow2);
  color: var(--ink);
  font-weight: 900;
  font-size: .85rem;
  white-space: nowrap;
}

.solLink{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  font-weight: 1000;
  color: #16A34A; /* green arrow sign */
}
.solLink span{ transition:.25s ease; }
.solCard:hover .solLink span{ transform: translateX(5px); }

/* CTA */
.solCta{ padding: 10px 0 70px; }
.solCta__card{
  border-radius: calc(var(--r) + 14px);
  border: 1px solid rgba(2,6,23,.12);
  background:
    radial-gradient(700px 260px at 15% 0%, rgba(231,61,84,.16), transparent 60%),
    radial-gradient(700px 260px at 90% 10%, rgba(3,81,148,.16), transparent 58%),
    #fff;
  box-shadow: 0 26px 60px rgba(2,6,23,.12);
  padding: 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
}
.solCta__actions{ display:flex; gap: 10px; flex-wrap:wrap; }

/* Responsive steps */
@media (max-width: 1400px){
  .solGrid{ grid-template-columns: repeat(4, minmax(0,1fr)); }
}
@media (max-width: 1180px){
  .solGrid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 900px){
  .solGrid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .solHero{ min-height: auto; padding: 84px 0 60px; }
}
@media (max-width: 560px){
  .solGrid{ grid-template-columns: 1fr; }
  .solCta__card{ flex-direction:column; align-items:flex-start; }
}

/* =========================================
   Solutions Intro — Clean + Readable + Hover
========================================= */

.solIntro{
  padding: 70px 0;
  position: relative;
  overflow: hidden;
}

/* premium soft background */
.solIntro::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 500px at 10% 0%, rgba(3,81,148,.08), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(231,61,84,.08), transparent 55%);
  pointer-events:none;
}

/* content card */
.solIntro__head{
  position: relative;
  border-radius: 22px;
  padding: 30px 32px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(2,6,23,.10);
  box-shadow: 0 24px 60px rgba(2,6,23,.08);
  transition: .35s ease;
  will-change: transform;
}

/* glow layer */
.solIntro__head::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(600px 260px at 15% 0%, rgba(231,61,84,.14), transparent 60%),
    radial-gradient(600px 260px at 85% 10%, rgba(3,81,148,.14), transparent 60%);
  opacity:0;
  transition:.35s ease;
  pointer-events:none;
}

/* hover effect */
.solIntro__head:hover{
  transform: translateY(-6px);
  box-shadow: 0 36px 90px rgba(2,6,23,.12);
  border-color: rgba(3,81,148,.25);
}
.solIntro__head:hover::after{
  opacity: 1;
}

/* title */
.solTitle{
  margin:0;
  color: var(--ink);
  font-size: clamp(26px, 2.6vw, 40px);
  font-weight: 1150;
  letter-spacing: -.5px;
  line-height: 1.15;
}

/* paragraph readability improvement */
.solLead{
  margin-top: 16px;
  color: #334155;
  font-weight: 680;
  font-size: 1.05rem;
  line-height: 1.95;        /* increased line spacing */
  letter-spacing: .2px;     /* improves readability */
  text-align: justify;
}

/* strong emphasis */
.solLead strong{
  color: var(--ink);
  font-weight: 950;
}

/* mobile spacing */
@media (max-width: 560px){
  .solIntro__head{
    padding: 22px;
  }
  .solLead{
    font-size: 1rem;
    line-height: 1.85;
  }
}

