.ssb-footer{
  position:relative;
  overflow:hidden;
  padding:18px 26px 16px;
  background:var(--footer-bg);
  border-top:1px solid rgba(255,255,255,.20);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    0 -10px 24px rgba(12,45,96,.08);
}

.ssb-footer::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 28%),
    radial-gradient(circle at 82% 22%, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 26%);
  opacity:.9;
}

.footer-shell{
  position:relative;
  z-index:1;
  max-width:1360px;
  margin:0 auto;
  padding:16px 26px 14px;
  border-radius:24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.05) 100%);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    0 14px 30px rgba(15,46,96,.10);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.footer-desktop-grid{
  display:grid;
  grid-template-columns:1fr 1px auto 1px 1fr;
  align-items:center;
  gap:22px;
}

.footer-desktop-left{ text-align:left; }

.footer-desktop-center{
  display:flex;
  justify-content:center;
  align-items:center;
  text-align:center;
  width:100%;
}

.footer-desktop-right{ text-align:right; }

.footer-desktop-divider{
  width:1px;
  height:96px;
  background:linear-gradient(
    180deg,
    transparent 0%,
    rgba(255,255,255,.30) 18%,
    rgba(255,255,255,.30) 82%,
    transparent 100%
  );
}

.footer-company-th{
  font-size:18px;
  line-height:1.2;
  font-weight:800;
  color:#ffffff;
  margin-bottom:6px;
}

.footer-company-en{
  font-size:15px;
  line-height:1.35;
  font-weight:700;
  color:rgba(255,255,255,.92);
  margin-bottom:10px;
}

.footer-address,
.footer-reg{
  font-size:14px;
  line-height:1.65;
  font-weight:500;
  color:rgba(255,255,255,.88);
}

.footer-phone-label{
  font-size:14px;
  line-height:1.2;
  font-weight:700;
  color:rgba(255,255,255,.78);
  margin-bottom:10px;
}

.footer-phone{
  display:inline-flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  width:100%;
  font-size:18px;
  line-height:1.35;
  font-weight:800;
  color:#ffffff;
  margin-bottom:8px;
  white-space:nowrap;
}

.footer-phone-icon{
  width:18px;
  height:18px;
  flex:0 0 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.92);
}

.footer-phone-icon svg{
  width:18px;
  height:18px;
  display:block;
}

.footer-icons{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  width:100%;
  margin:0 auto;
}

.footer-icons a{
  width:50px;
  height:50px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(244,248,255,.96) 100%);
  border:1px solid rgba(255,255,255,.28);
  box-shadow:
    0 10px 22px rgba(14,43,92,.16),
    inset 0 1px 0 rgba(255,255,255,1);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.footer-icons a:hover{
  transform:translateY(-2px);
  box-shadow:
    0 14px 28px rgba(14,43,92,.20),
    inset 0 1px 0 rgba(255,255,255,1);
  border-color:rgba(255,255,255,.44);
}

.footer-icons img{
  width:22px;
  height:22px;
  object-fit:contain;
  display:block;
}

.footer-bottom-line{
  height:1px;
  margin:16px 0 12px;
  background:linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,.26) 14%,
    rgba(255,255,255,.26) 86%,
    transparent 100%
  );
}

.footer-copy{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  width:100%;
}

.footer-copy div:first-child{
  font-size:14px;
  line-height:1.45;
  font-weight:700;
  color:rgba(255,255,255,.94);
  margin-bottom:2px;
  letter-spacing:.2px;
}

.footer-copy div:last-child{
  font-size:12px;
  line-height:1.45;
  font-weight:600;
  color:rgba(255,255,255,.78);
  letter-spacing:.2px;
}
