/* ================================================================
   Si:d Base — shared classes used across multiple components
   Exact match of vivesid.com global patterns
   ================================================================ */

/* ── Bootstrap 5 grid subset ── */

.container,
.container-fluid {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-right: auto;
  margin-left: auto;
}

.container {
  max-width: 1200px;
}

@media (max-width: 575.98px) {
  .container { max-width: 100%; }
}

@media (min-width: 576px) {
  .container { max-width: 540px; }
}

@media (min-width: 768px) {
  .container { max-width: 720px; }
}

@media (min-width: 992px) {
  .container { max-width: 960px; }
}

@media (min-width: 1200px) {
  .container { max-width: 1140px; }
}

@media (min-width: 1400px) {
  .container { max-width: 1320px; }
}

.row {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}

.row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

.g-0 {
  --bs-gutter-x: 0;
  --bs-gutter-y: 0;
}

.col-12 { flex: 0 0 auto; width: 100%; }

/* sm ≥ 576px */
@media (min-width: 576px) {
  .col-sm-11 { flex: 0 0 auto; width: 91.66666667%; }
  .col-sm-12 { flex: 0 0 auto; width: 100%; }
}

/* md ≥ 768px */
@media (min-width: 768px) {
  .col-md-4  { flex: 0 0 auto; width: 33.33333333%; }
  .col-md-6  { flex: 0 0 auto; width: 50%; }
  .col-md-10 { flex: 0 0 auto; width: 83.33333333%; }
  .col-md-12 { flex: 0 0 auto; width: 100%; }
}

/* lg ≥ 992px */
@media (min-width: 992px) {
  .col-lg-3  { flex: 0 0 auto; width: 25%; }
  .col-lg-4  { flex: 0 0 auto; width: 33.33333333%; }
  .col-lg-6  { flex: 0 0 auto; width: 50%; }
  .col-lg-8  { flex: 0 0 auto; width: 66.66666667%; }
  .col-lg-12 { flex: 0 0 auto; width: 100%; }
}

/* xl ≥ 1200px */
@media (min-width: 1200px) {
  .col-xl-4  { flex: 0 0 auto; width: 33.33333333%; }
  .col-xl-5  { flex: 0 0 auto; width: 41.66666667%; }
  .col-xl-6  { flex: 0 0 auto; width: 50%; }
  .col-xl-7  { flex: 0 0 auto; width: 58.33333333%; }
  .col-xl-8  { flex: 0 0 auto; width: 66.66666667%; }
  .col-xl-12 { flex: 0 0 auto; width: 100%; }
}

/* ── Bootstrap utility classes ── */

.position-relative { position: relative; }
.align-items-center { align-items: center; }
.container-fluid { max-width: 100%; }
.container-section { width: 100%; max-width: 100%; padding: 0; }

/* ── Global CTA button — exact vivesid.com implementation ── */

.global__button {
  display: table;
  min-width: 170px;
  height: 48px;
  position: relative;
  border-radius: 56px;
  border: 1px solid #fff;
  overflow: hidden;
  text-decoration: none;
}

.global__button:hover .bg-fill {
  background: rgba(186, 197, 185, 0.1);
}

.global__button:hover .circle {
  width: 100%;
  height: 100%;
  border-radius: 0;
}

.global__button .bg-fill {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: rgba(186, 197, 185, 0.24);
  font-weight: 600;
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  margin: 0 auto;
  transition: 0.3s;
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
}

.global__button .circle {
  width: 1px;
  height: 1px;
  background: #2b514d;
  border-radius: 120px 120px 0 0;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 0;
  margin: 0 auto;
  transition: 0.3s;
}

.global__button.btn-green {
  border: 1px solid #2b514d;
}

.global__button.btn-green .bg-fill {
  background: rgba(186, 197, 185, 0.5);
  color: #2b514d;
}

.global__button.btn-green:hover .bg-fill {
  background: rgba(186, 197, 185, 0);
  color: #fff;
}
