/* SAVI Downloads – Elementor Widget */
.savi-downloads{
  --blue:#1D344A;
  --blue-dark:#15293C;
  --orange:#E63323;
  background:#fff;
  padding:34px 0 70px;
}

/* ============================= */
/* Banner */
/* ============================= */

.savi-downloads-hero{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  min-height:220px;
  background:var(--blue);
  margin:0 30px;
}

.savi-downloads-hero-bg{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(29,52,74,.90) 0%, rgba(29,52,74,.62) 60%, rgba(29,52,74,.30) 100%),
    var(--bg) center/cover no-repeat;
}

.savi-downloads-hero-inner{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  padding:52px 30px;
}

.savi-downloads-title{
  color:#fff;
  font-size:34px;
  font-weight:900;
  margin:0;
}

.savi-downloads-line{
  width:140px;
  height:4px;
  background:var(--orange);
  border-radius:999px;
  margin-top:14px;
}

.savi-downloads-sub{
  margin:14px 0 0;
  max-width:720px;
  color:rgba(255,255,255,.92);
  font-weight:600;
  line-height:1.6;
  font-size:15px;
}

/* ============================= */
/* Layout */
/* ============================= */

.savi-downloads-wrap{
  max-width:1200px;
  margin:0 auto;
  padding:26px 30px 0;
}

.savi-downloads-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
  align-items:flex-start;
}

/* ============================= */
/* Card */
/* ============================= */

.savi-dl-card{
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(29,52,74,.12);
  box-shadow:0 14px 36px rgba(0,0,0,.08);
  overflow:hidden;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.savi-dl-card:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 60px rgba(0,0,0,.12);
  border-color:rgba(230,51,35,.28);
}

.savi-dl-card-head{
  padding:18px;
  display:flex;
  gap:14px;
  align-items:center;
}

.savi-dl-ico{
  width:46px;
  height:46px;
  border-radius:999px;
  background:rgba(29,52,74,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:var(--blue);
  font-size:20px;
  line-height:1;
}

.savi-dl-ico svg{
  width:20px;
  height:20px;
  display:block;
}

.savi-dl-meta{
  flex:1 1 65%;
  min-width:0;
  padding-right:6px;
}

.savi-dl-title{
  margin:0;
  color:var(--blue);
  font-weight:900;
  font-size:15.5px;
  line-height:1.25;
}

.savi-dl-desc{
  margin:6px 0 0;
  color:rgba(29,52,74,.78);
  font-weight:700;
  font-size:13.4px;
  line-height:1.55;
}

/* ============================= */
/* Buttons */
/* ============================= */

.savi-dl-actions{
  margin-left:auto;
  display:flex;
  gap:8px;
  align-items:flex-start;
  flex:0 0 auto;
  flex-wrap:nowrap;
}

.savi-dl-btn{
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none !important;
  font-weight:900;
  font-size:12px;
  line-height:1;
  color:#fff !important;
  background:var(--orange);
  border-radius:999px;
  padding:8px 12px;
  box-shadow:0 12px 30px rgba(230,51,35,.20);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  white-space:nowrap;
  min-width:0;
  justify-content:center;
}

.savi-dl-btn svg{
  stroke:currentColor;
  width:14px !important;
  height:14px !important;
  display:block !important;
  flex:0 0 auto;
}

.savi-dl-btn:hover{
  background:var(--blue-dark);
  transform:translateY(-1px);
  box-shadow:0 16px 36px rgba(0,0,0,.16);
}

.savi-dl-btn:active{
  transform:translateY(0);
}

/* ============================= */
/* Responsive */
/* ============================= */

@media (max-width: 980px){
  .savi-downloads-hero{
    border-radius:14px;
    margin:0 18px;
  }

  .savi-downloads-hero-inner{
    padding:40px 18px;
  }

  .savi-downloads-title{
    font-size:26px;
  }

  .savi-downloads-wrap{
    padding:22px 18px 0;
  }

  .savi-downloads-grid{
    grid-template-columns:repeat(2,1fr);
    gap:18px;
  }
}

/* ✅ FIX TYLKO NA MOBILE: zrzucenie przycisków pod opis + brak nachodzenia */
@media (max-width: 520px){
  .savi-downloads-grid{
    grid-template-columns:1fr;
  }

  /* klucz: pozwól elementom się zawinąć */
  .savi-dl-card-head{
    flex-wrap:wrap;
    align-items:flex-start;
  }

  /* meta niech zostanie obok ikonki, ale może się zwężać */
  .savi-dl-meta{
    flex:1 1 calc(100% - 60px);
    min-width:0;
  }

  /* akcje schodzą pod spodem na pełną szerokość, wyrównane do tekstu (pod ikoną) */
  .savi-dl-actions{
    flex:1 1 100%;
    width:100%;
    margin-left:0;
    padding-left:60px;   /* 46px ikonka + ~14px gap */
    flex-direction:column;
    gap:8px;
    align-items:stretch;
  }

  /* przyciski full width, żeby nie rozjeżdżało */
  .savi-dl-btn{
    width:100%;
    padding:10px 12px;
    justify-content:space-between;
  }
}