.elementor-39544 .elementor-element.elementor-element-6ab5f8a{--display:flex;--background-transition:0.3s;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-39544 .elementor-element.elementor-element-db18fff{width:100%;max-width:100%;}.elementor-39544 .elementor-element.elementor-element-db18fff > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-39544 .elementor-element.elementor-element-a3b7bd7{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:flex-start;--gap:30px 30px;--background-transition:0.3s;--padding-top:0px;--padding-bottom:25px;--padding-left:0px;--padding-right:0px;}.elementor-39544 .elementor-element.elementor-element-a3b7bd7.e-con{--align-self:center;}.elementor-39544 .elementor-element.elementor-element-27de9b8{--display:flex;--background-transition:0.3s;}.elementor-39544 .elementor-element.elementor-element-1c9277a{--display:flex;--min-height:0px;--gap:0px 0px;--background-transition:0s;--border-radius:0px 0px 0px 0px;}.elementor-39544 .elementor-element.elementor-element-1c9277a.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-39544 .elementor-element.elementor-element-1540602{width:var( --container-widget-width, 100% );max-width:100%;--container-widget-width:100%;--container-widget-flex-grow:0;}.elementor-39544 .elementor-element.elementor-element-1540602 > .elementor-widget-container{margin:0px 0px 120px 0px;border-radius:10px 10px 10px 10px;}.elementor-39544 .elementor-element.elementor-element-1540602 iframe{height:550px;filter:brightness( 100% ) contrast( 100% ) saturate( 100% ) blur( 0px ) hue-rotate( 0deg );transition-duration:0s;}body.elementor-page-39544{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}body.elementor-page-39544:not(.elementor-motion-effects-element-type-background), body.elementor-page-39544 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}@media(min-width:768px){.elementor-39544 .elementor-element.elementor-element-6ab5f8a{--content-width:100%;}.elementor-39544 .elementor-element.elementor-element-a3b7bd7{--width:900px;}.elementor-39544 .elementor-element.elementor-element-1c9277a{--content-width:900px;}}@media(max-width:1024px) and (min-width:768px){.elementor-39544 .elementor-element.elementor-element-a3b7bd7{--width:100%;}}@media(max-width:1024px){.elementor-39544 .elementor-element.elementor-element-a3b7bd7{--justify-content:center;--gap:50px 50px;--padding-top:0px;--padding-bottom:25px;--padding-left:0px;--padding-right:0px;}}@media(max-width:767px){.elementor-39544 .elementor-element.elementor-element-a3b7bd7{--gap:40px 40px;--padding-top:0px;--padding-bottom:25px;--padding-left:0px;--padding-right:0px;}.elementor-39544 .elementor-element.elementor-element-1c9277a{--margin-top:0px;--margin-bottom:10px;--margin-left:0px;--margin-right:0px;}}/* Start custom CSS for shortcode, class: .elementor-element-db18fff *//* 背景区 */
  .custom-section {
    background: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)),var(--wpr-bg-5bfa8a58-5c71-4442-8c25-4e526a5a526d) center no-repeat;
    background-position: 0% 90%;
    background-size: 105% auto;
    color: #fff;
    height: 600px;
    display: flex;
    /*align-items: center;*/
    justify-content: center;
    text-align: center;
    padding: 20px;
    width: 100% !important;   /* Elementor 里的容器有时会限制 */
    max-width: 100% !important;
  }
  
  .content-wrapper{
      margin-top: 110px;
  }

  .section-title {
    font-size: 64px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #fff
  }
  .contact-desc {
    font-size: 16px;
    color: #ccc;
    line-height: 20px;
  }

  .section-subtitle {
    font-size: 16px;
    color: #ccc;
  }

  /* 整体悬浮模块 */
  .contact-section {
    max-width: 900px;
    align-items: stretch;
    margin: -250px auto 40px; /* 关键：往上浮出一半 */
    /*padding: 0 20px;*/
    position: relative;
    z-index: 10;
    /*height: 700px;*/
  }

  .contact-wrapper {
    display: flex;
    background: #fff;
    border-radius: 15px;
    box-shadow: 0 10px 35px rgba(0, 0, 0, 0.1); 
    overflow: hidden;
    padding:20px;
  }

  /* 左侧信息 */
  .contact-info {
    flex: 1;
    padding: 30px;
    display: flex;
    flex-direction: column;
  }
  .detail-item .iconfont {
      position: relative;
      padding-right: 10px;
      color: #e3194c;
      top: 4px;
  }

  .contact-title {
    font-size: 2rem;
    margin-bottom: 10px;
    font-weight: 700;
  }

/* 信息卡片容器 */
.contact-details {
  margin-top: 20px; /* 与标题区拉开一点距离 */
  display: flex;
  flex-direction: column;
  gap: 15px; /* 卡片之间的间距 */
  width: 100%;
  
}

/* 单个信息卡片 */
.detail-item {
  border: 1px solid #ddd;
  border-radius: 8px;
  padding: 10px 20px;
  height: 120px;
  transition: transform 0.2s, box-shadow 0.2s;
  margin-bottom: 20px;
}

/* 卡片 hover 效果 */
.detail-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.15);
}

/* 卡片标题 */
.detail-item h4 {
  margin: 0 0 8px;
  font-size: 1.1rem;
}

/* 卡片内容 */
.detail-item p {
  margin: 0;
}

  /* 右侧表单 */
  .contact-form {
    flex: 1.2;
    padding:30px;
    /*margin: 30px;*/
  }

  .contact-form form {
    width: 100%;
    border: 1px solid #ddd;
    border-radius: 10px;
    padding: 35px 20px 34px 20px;
    max-height: 100%;
    background-color: #f6f6f6;
  }
  
  div .wpcf7{
      margin-bottom: 0px !important;
  }
  
  .btn-submit.wpcf7-submit {
  display: inline-block;
  width: 100%;               /* 自适应内容宽度，也可以改 100% */
  padding: 10px 25px;        /* 上下左右内边距 */
  background: #000;          /* 背景色 */
  color: #fff;               /* 文字颜色 */
  font-size: 16px;
  font-weight: bold;
  border-radius: 6px;
  border: none;
  cursor: pointer;
  transition: background 0.3s, transform 0.2s;
}

.btn-submit.wpcf7-submit:hover {
    background-color:#e3194c !important;
}

.form-group p{
  line-height: 0px !important;  
}
.form-group input, .form-group select, .form-group textarea{
    margin-bottom: 10px
}
.file-upload .wpcf7-not-valid-tip{
    top: 45px;
}
.wpcf7-not-valid-tip{
    top: 0px !important;
}

.form-container {
  max-width: 1000px;
  margin: auto;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  padding: 20px;
}

.form-container h2 {
  margin-top: 0;
  font-size: 22px;
  font-weight: bold;
}

.form-container hr {
  border: none;
  border-top: 1px solid #ddd;
  /*margin: 15px;*/
}

/*.form-group {*/
/*  margin-bottom: 20px;*/
/*}*/

.form-group label {
  display: block;
  /*margin-bottom: 6px;*/
  font-weight: 600;
}

.form-group label span {
  color: red;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  /*padding: 10px;*/
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  box-sizing: border-box;
  transition: border 0.3s;
  outline: none;
}

.form-group textarea {
  resize: vertical;
  height: 60px;
  min-height: 60px;
}

/*.form-group input:focus,*/
/*.form-group select:focus,*/
/*.form-group textarea:focus {*/
/*  border-color: #000;*/
/*}*/

.error {
  border-color: red !important;
}

.file-upload {
  position: relative;
  border: 1px dashed #aaa;
  border-radius: 6px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #555;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  background: #fff;
  overflow: hidden;
  margin-bottom: 15px;
}

.file-upload:hover {
  background: #f9f9f9;
  border-color: #333;
}
.preview {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-top: 10px;
}
.preview-item {
  position: relative;
  padding: 6px 28px 6px 10px;
  background: #f5f5f5;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
}
.remove-btn {
  position: absolute;
  top: 2px;
  right: 6px;
  cursor: pointer;
  color: #888;
  font-weight: bold;
  font-size: 16px;
  line-height: 1;
}
.remove-btn:hover {
  color: #e3194c;
}
.send-fat p{
    height: 53px;
}
/*底部信息*/
.wpcf7-response-output{
    margin:0 !important;
    /*color: #DC3232 !important;*/
}
.wpcf7-spinner{
    top: -37px !important;
    right: -145px;
}

/* 遮罩层 */
.file-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  justify-content: center;
  align-items: center;
  z-index: 9999;
}
.file-overlay.active {
  display: flex;
}
.file-overlay-content {
  max-width: 100%;
  max-height: 100%;
  display: flex;          
  justify-content: center;
  align-items: center;
}
.file-overlay-content img,
.file-overlay-content video {
  max-width: 50%;
  max-height: 50%;
  object-fit: contain;
  border-radius: 6px;
}

/* 让 label 占据整个区域，文字居中 */
.file-upload label {
  position: absolute;
  inset: 0; /* top/right/bottom/left 全覆盖 */
  display: flex;
  top: 5px;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  margin: 0;
}

/* 把 input 完全覆盖整个框，透明但可点 */
.file-upload input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}
.wpcf7 p {
    margin-bottom: 11px !important;
}

/* 平板端 */
@media (min-width: 768px) and (max-width: 1024px) {
  .custom-section {
    background-position: 0% 100%;
    background-size: 115% 190%;
  }
  .contact-wrapper {
    margin:0px 40px;
  }
}

/*大屏手机 */
@media (max-width: 768px) {
  .contact-wrapper {
    flex-direction: column; 
    margin: 0 10px;
  }
  .custom-section {
    background-position: 40% 100%;
    background-size: 330% 190%;
  }

  .contact-info {
    width: 100%;
    padding: 0px;
  }

  .contact-form {
    width: 100%;
    padding: 0px;
    margin-top: 20px; /* 避免紧贴信息区 */
  }

  .section-title {
    font-size: 40px; /* 比桌面小，但比手机大 */
  }

  .btn-submit.wpcf7-submit {
    font-size: 15px;
    padding: 10px 20px;
  }
}

@media (max-width: 380px) {
  .contact-wrapper {
    flex-direction: column; 
    margin:0px 10px;
  }
  .custom-section {
    background-size: 290% 170%;       /* 同样填满 */
    background-position: 40% 100%;
  }

  
  .contact-info{
      width:100%;
      padding:0px;
  }
  .contact-form {
    width: 100%;
    padding: 0px;   /* 更小内边距 */
  }
  
  .section-title {
    font-size: 32px; /* 小屏标题缩小 */
  }


  .btn-submit.wpcf7-submit {
    font-size: 14px;   /* 按钮小一点 */
    padding: 8px 15px;
  }
  
  .wpcf7-spinner{
    right: -105px;
}
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-a3b7bd7 */.elementor-widget-container {
  position: relative;
  overflow: hidden;
}

/*.elementor-widget-image .elementor-widget-container a::after {*/
/*  content: "";*/
/*  position: absolute;*/
/*  inset: 0;*/
/*  background: rgba(255, 255, 255, 0);*/
/*  transition: background 0.3s ease;*/
/*}*/

/*.elementor-widget-image .elementor-widget-container a:hover::after {*/
/*  background: rgba(255, 255, 255, 0.6);*/
  /*background: rgba(227, 25, 76, 0.1);*/
/*}*/

/*------------------*/
/*.elementor-widget-image .elementor-widget-container a:hover img {*/
/*  filter: invert(28%) sepia(95%) saturate(6372%) hue-rotate(330deg) brightness(91%) contrast(95%);*/
/*}*/

/*------------------*/
/* 仅针对 a 内部的 img */
.elementor-widget-image .elementor-widget-container a {
  position: relative;
  display: inline-block;
  overflow: hidden;
}

.elementor-widget-image .elementor-widget-container a img {
  display: block;
  transition: transform 0.4s ease;
}

/* 红色蒙层仅作用在 a 上 */
.elementor-widget-image .elementor-widget-container a::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(227, 25, 76, 0);
  mix-blend-mode: lighten; /* 可尝试 overlay/screen */
  transition: background-color 0.4s ease;
  pointer-events: none;
}

.elementor-widget-image .elementor-widget-container a:hover::after {
  background-color: rgba(227, 25, 76, 1);
}

.elementor-widget-image .elementor-widget-container a:hover img {
  transform: scale(1.05);
}/* End custom CSS */