/* ===============================
   DSXRDZGROUP Footer Styles
================================ */

.dsxrdzgroup-footer * {
  box-sizing: border-box;
}

/* ===== Layout Container ===== */
.dsxrdzgroup-footer {
  margin: 0 auto;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 60px;
  background: #fff;
}

/* ===== Left Area ===== */
.dsxrdzgroup-footer .footer-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.dsxrdzgroup-footer .footer-left .brand {
  margin-bottom: 30px;
  display: flex;
  flex-direction: column !important;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.dsxrdzgroup-footer .logo {
  max-width: 150px;
}

.dsxrdzgroup-footer .brand span {
  display: block;
  margin-top: 6px;
  color: #111;
  font-weight: 500;
  font-size: 18px;
}

/* ===== Right Area ===== */
.dsxrdzgroup-footer .footer-right {
  display: block; /* base; overridden in desktop media to grid */
}

.dsxrdzgroup-footer .footer-right .col {
  display: block; /* guard against external flex overrides */
}

.dsxrdzgroup-footer .col h4 {
  margin-bottom: 14px;
  font-weight: 600;
  font-size: 14px;
  color: #111;
}

.dsxrdzgroup-footer .col a {
  display: block;
  margin-bottom: 8px;
  color: #555;
  text-decoration: none;
  font-size: 13px;
  transition: color 0.3s;
}

.dsxrdzgroup-footer .col a:hover {
  color: #555;
}

/* ===== Visibility Control ===== */
.dsxrdzgroup-footer .mobile-only {
  display: none;
}

.dsxrdzgroup-footer .pc-only {
  display: block;
}

/* Explicit desktop enforcement to avoid overlap when resizing */
@media (min-width: 769px) {
  .dsxrdzgroup-footer .pc-only {
    display: block !important;
  }
  
  .dsxrdzgroup-footer .mobile-only {
    display: none !important;
  }

  /* ensure desktop grid visible on desktop widths even if both classes exist */
  .dsxrdzgroup-footer .footer-right.pc-only {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 40px;
    align-items: start;
    width: 100%;
  }
}

/* ===============================
   Large Desktop (≤1199px)
================================ */
@media (max-width: 1199px) {
  .dsxrdzgroup-footer {
    grid-template-columns: 260px 1fr;
    gap: 40px;
  }

  .dsxrdzgroup-footer .footer-right {
    gap: 30px;
  }
}

/* ===============================
   Tablet (769px–991px)
================================ */
@media (max-width: 991px) and (min-width: 769px) {
  .dsxrdzgroup-footer {
    grid-template-columns: 1fr;
    gap: 30px;
    padding: 30px 24px;
  }

  .dsxrdzgroup-footer .footer-left {
    align-items: center;
    text-align: center;
  }

  .dsxrdzgroup-footer .footer-left .brand {
    margin-bottom: 10px;
  }

  .dsxrdzgroup-footer .footer-right {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
}

/* ===============================
   Mobile (≤768px)
================================ */
@media (max-width: 768px) {
  .dsxrdzgroup-footer {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  /* Hide desktop grid on mobile to avoid overlap during resize */
  .dsxrdzgroup-footer .footer-right,
  .dsxrdzgroup-footer .footer-right.pc-only {
    display: none !important;
  }

  .dsxrdzgroup-footer .footer-left .brand {
    margin-bottom: 0;
    flex-direction: row !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-align: center;
  }

  .dsxrdzgroup-footer .logo {
    max-width: 88px;
  }

  .dsxrdzgroup-footer .brand span {
    margin-top: 0;
    font-size: 15px;
  }

  .dsxrdzgroup-footer .pc-only {
    display: none !important;
  }

  .dsxrdzgroup-footer .mobile-only {
    display: block !important;
  }

  /* extra guard: show mobile wrapper when both classes might coexist */
  .dsxrdzgroup-footer .footer-mobile.mobile-only {
    display: block !important;
  }

  /* ===== Accordion ===== */
  .dsxrdzgroup-footer .accordion {
    background: #f9fafb;
    border-radius: 16px;
    margin-bottom: 12px;
    overflow: hidden;
  }

  .dsxrdzgroup-footer .acc-header {
    padding: 14px 16px;
    position: relative;
    font-weight: 500;
    font-size: 13px;
    cursor: pointer;
  }

  .dsxrdzgroup-footer .acc-header::after {
    content: "+";
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    transition: all 0.3s;
  }

  .dsxrdzgroup-footer .accordion.active .acc-header::after {
    content: "—";
  }

  .dsxrdzgroup-footer .acc-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    padding: 0 16px;
  }

  .dsxrdzgroup-footer .acc-body a {
    display: block;
    padding: 12px 0;
    font-size: 13px;
    color: #555;
    text-decoration: none;
  }
}
