/* qiyueyun cart theme
   独立购物车样式层：所有新样式均使用 qy-cart 前缀，避免污染用户中心/官网其他页面
*/

:where(.qy-cart-page, .qy-cart-v10-shell) {
  --qy-cart-primary: #1263ff;
  --qy-cart-sky: #20b8ff;
  --qy-cart-title: #0f172a;
  --qy-cart-text: #475569;
  --qy-cart-muted: #64748b;
  --qy-cart-line: #e2e8f0;
  --qy-cart-soft-line: #eef3f8;
  --qy-cart-soft: #f8fbff;
  --qy-cart-blue-soft: #edf4ff;
  --qy-cart-white: #ffffff;
  --qy-cart-danger: #ef4444;
  --qy-cart-shadow-sm: 0 10px 24px rgba(15, 23, 42, 0.06);
  --qy-cart-shadow: 0 22px 62px rgba(15, 23, 42, 0.08);
  color: var(--qy-cart-title);
  font-family: "Source Han Serif SC", "Noto Serif CJK SC", "Microsoft YaHei", Arial, sans-serif;
}

.qy-cart-page {
  position: relative;
  overflow: hidden;
  padding: 6px 0 34px;
}

.qy-cart-page::before {
  content: "";
  position: absolute;
  right: -240px;
  top: -240px;
  width: 460px;
  height: 460px;
  border-radius: 999px;
  background: rgba(18, 99, 255, 0.08);
  pointer-events: none;
}

.qy-cart-page .row,
.qy-cart-page .card,
.qy-cart-page form,
.qy-cart-page .modal {
  position: relative;
  z-index: 1;
}

.qy-cart-page .card {
  border: 1px solid rgba(226, 232, 240, 0.92) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.06), transparent 30%),
    var(--qy-cart-white) !important;
  box-shadow: var(--qy-cart-shadow) !important;
}

.qy-cart-page .card-header {
  border-bottom: 1px solid var(--qy-cart-soft-line) !important;
  background: transparent !important;
}

.qy-cart-page .card-header h5,
.qy-cart-page h5,
.qy-cart-page h4,
.qy-cart-page h3 {
  color: var(--qy-cart-title);
  font-weight: 900;
}

.qy-cart-page .card-body {
  border-radius: inherit;
}

.qy-cart-page .btn-primary,
.qy-cart-page .btn-success {
  border: 0 !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, var(--qy-cart-primary), var(--qy-cart-sky)) !important;
  box-shadow: 0 14px 30px rgba(18, 99, 255, 0.22);
  font-weight: 900;
}

.qy-cart-page .btn-primary:hover,
.qy-cart-page .btn-success:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 42px rgba(18, 99, 255, 0.28);
}

.qy-cart-page .btn-outline-primary {
  color: var(--qy-cart-primary) !important;
  border-color: #cfe0ff !important;
  border-radius: 999px !important;
  background: var(--qy-cart-white) !important;
  font-weight: 900;
}

.qy-cart-page .btn-outline-primary:hover {
  color: #ffffff !important;
  background: linear-gradient(135deg, var(--qy-cart-primary), var(--qy-cart-sky)) !important;
}

.qy-cart-page .form-control,
.qy-cart-page .custom-select,
.qy-cart-page .bootstrap-select > .dropdown-toggle {
  min-height: 42px;
  border-color: var(--qy-cart-line) !important;
  border-radius: 14px !important;
  background-color: var(--qy-cart-white) !important;
  box-shadow: none !important;
}

.qy-cart-page .form-control:focus,
.qy-cart-page .custom-select:focus,
.qy-cart-page .bootstrap-select > .dropdown-toggle:focus {
  border-color: #93c5fd !important;
  box-shadow: 0 0 0 4px rgba(18, 99, 255, 0.08) !important;
}

.qy-cart-page .table {
  overflow: hidden;
  border-radius: 18px;
}

.qy-cart-page .table th {
  color: var(--qy-cart-title);
  border-color: var(--qy-cart-soft-line) !important;
  background: var(--qy-cart-soft);
  font-weight: 900;
}

.qy-cart-page .table td {
  border-color: var(--qy-cart-soft-line) !important;
}

.qy-cart-page .pagination .page-link {
  min-width: 34px;
  min-height: 34px;
  margin: 0 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--qy-cart-primary);
  border-color: #dbeafe;
  border-radius: 999px !important;
  background: #ffffff;
  font-weight: 900;
}

.qy-cart-page .pagination .active .page-link,
.qy-cart-page .pagination .page-link:hover {
  color: #ffffff;
  background: linear-gradient(135deg, var(--qy-cart-primary), var(--qy-cart-sky));
}

/* 产品列表 */
.qy-cart-product-page > .row {
  align-items: stretch;
}

.qy-cart-product-page .prolist .card.bg-primary {
  overflow: hidden;
  border: 0 !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 100% 0, rgba(255, 255, 255, 0.22), transparent 34%),
    linear-gradient(135deg, #1263ff 0%, #20b8ff 100%) !important;
  box-shadow: 0 24px 64px rgba(18, 99, 255, 0.20) !important;
}

.qy-cart-product-page .pro-search-box .form-control {
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, 0.28) !important;
  background: rgba(255, 255, 255, 0.13) !important;
}

.qy-cart-product-page .pro-search-box .form-control::placeholder {
  color: rgba(255, 255, 255, 0.82) !important;
}

.qy-cart-product-page .firstbox,
.qy-cart-product-page .secondbox {
  border-radius: 20px;
}

.qy-cart-product-page .firstbox li a,
.qy-cart-product-page .secondbox li a {
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 4px 0;
  padding: 0 10px;
  border-radius: 13px;
  color: var(--qy-cart-text) !important;
  font-weight: 900;
}

.qy-cart-product-page .firstbox .active a,
.qy-cart-product-page .secondbox .active a,
.qy-cart-product-page .firstbox li a:hover,
.qy-cart-product-page .secondbox li a:hover {
  color: var(--qy-cart-primary) !important;
  background: var(--qy-cart-blue-soft) !important;
}

.qy-cart-product-page .card .card .card-header {
  padding: 18px 18px 0;
}

.qy-cart-product-page .card .card .card-body {
  padding: 18px;
}

.qy-cart-product-page .card pre {
  color: var(--qy-cart-muted);
  font-size: 13px;
  line-height: 1.75;
}

.qy-cart-product-page .card .text-right[style*="#e64a19"] {
  color: var(--qy-cart-primary) !important;
  font-size: 16px;
  font-weight: 900;
}

/* 购物车结算 */
.qy-cart-view-page .goods_info {
  border: 1px solid var(--qy-cart-soft-line);
  border-radius: 16px;
  background: var(--qy-cart-soft);
}

.qy-cart-view-page .goods_info .title {
  color: var(--qy-cart-primary) !important;
  font-weight: 900;
}

.qy-cart-view-page .goods_info .info {
  color: var(--qy-cart-text);
}

.qy-cart-view-page .addfunds-payment,
.qy-cart-view-page .payType,
.qy-cart-view-page .checkboxDiv {
  border: 1px solid var(--qy-cart-line) !important;
  border-radius: 16px !important;
  background: #ffffff;
  transition: 0.18s ease;
}

.qy-cart-view-page .addfunds-payment:hover,
.qy-cart-view-page .addfunds-payment.active,
.qy-cart-view-page .payType.active,
.qy-cart-view-page .payType:hover,
.qy-cart-view-page .checkboxSelect {
  border-color: var(--qy-cart-primary) !important;
  background: var(--qy-cart-blue-soft) !important;
  box-shadow: 0 12px 26px rgba(18, 99, 255, 0.10);
}

.qy-cart-view-page .mobile-bottom-total {
  border-top: 1px solid var(--qy-cart-soft-line);
  box-shadow: 0 -14px 36px rgba(15, 23, 42, 0.10);
}

/* 配置页 */
.qy-cart-configure-page .cycle-select-discount {
  background: linear-gradient(135deg, #ef4444, #fb7185) !important;
}

.qy-cart-configure-page .error-tip {
  color: var(--qy-cart-danger) !important;
  font-weight: 800;
}

.qy-cart-configure-page .configoption_range {
  accent-color: var(--qy-cart-primary);
}

.qy-cart-configure-page .range_none {
  background: rgba(239, 68, 68, 0.15);
}

/* 订单汇总 */
.qy-cart-summary-page,
.qy-cart-page .ordersummary {
  color: var(--qy-cart-title);
}

.qy-cart-summary-page .ordersummary,
.qy-cart-page .ordersummary {
  overflow: hidden;
  border: 1px solid var(--qy-cart-soft-line);
  border-radius: 18px;
  background: var(--qy-cart-white);
}

.qy-cart-summary-page .ordersummary td,
.qy-cart-page .ordersummary td {
  padding: 10px 12px !important;
}

/* 完成页 */
.qy-cart-complete-page .twitter-bs-wizard {
  padding: 10px;
}

.qy-cart-complete-page .mdi-check-circle-outline {
  color: #16a34a !important;
  filter: drop-shadow(0 12px 22px rgba(22, 163, 74, 0.18));
}

/* V10 产品配置页 */
.qy-cart-v10-shell {
  min-height: 100vh;
  background:
    radial-gradient(circle at 12% 0, rgba(18, 99, 255, 0.08), transparent 28%),
    linear-gradient(180deg, #f8fbff 0%, #ffffff 50%);
}

.qy-cart-v10-shell .main-card {
  border-radius: 28px;
  background: #ffffff;
  box-shadow: var(--qy-cart-shadow);
}

.qy-cart-v10-shell .com-tit,
.qy-cart-v10-shell .config-tit,
.qy-cart-v10-shell .pro-tit {
  color: var(--qy-cart-title) !important;
  font-weight: 900 !important;
}

.qy-cart-v10-shell .el-button--primary,
.qy-cart-v10-shell .el-radio-button__orig-radio:checked + .el-radio-button__inner {
  border-color: var(--qy-cart-primary) !important;
  background: linear-gradient(135deg, var(--qy-cart-primary), var(--qy-cart-sky)) !important;
  box-shadow: 0 10px 22px rgba(18, 99, 255, 0.16) !important;
}

.qy-cart-v10-shell .el-input__inner,
.qy-cart-v10-shell .el-textarea__inner {
  border-color: var(--qy-cart-line) !important;
  border-radius: 14px !important;
}

.qy-cart-v10-shell .el-input__inner:focus,
.qy-cart-v10-shell .el-textarea__inner:focus {
  border-color: var(--qy-cart-primary) !important;
}

@media (max-width: 768px) {
  .qy-cart-page {
    padding-bottom: 76px;
  }

  .qy-cart-page .card {
    border-radius: 20px !important;
  }

  .qy-cart-product-page .firstbox,
  .qy-cart-product-page .secondbox {
    min-height: auto !important;
  }

  .qy-cart-page .btn {
    width: 100%;
  }
}



/* ===============================
   qy-cart：隐藏用户中心侧边栏
   仅在购物车模板主动给 body 添加 qy-cart-mode 后生效
   =============================== */
body.qy-cart-mode .vertical-menu {
  display: none !important;
}

body.qy-cart-mode .main-content {
  margin-left: 0 !important;
}

body.qy-cart-mode .page-content {
  padding-left: 0 !important;
}

body.qy-cart-mode #page-topbar {
  left: 0 !important;
}

body.qy-cart-mode .navbar-brand-box {
  border-right: 1px solid rgba(226, 232, 240, 0.86);
}

/* ===============================
   qy-cart：左侧产品分类 accordion
   =============================== */
.qy-cart-page .qy-cart-sidebar {
  align-items: flex-start;
}

.qy-cart-product-main {
  min-width: 0;
}

.qy-cart-category-card {
  position: sticky;
  top: 92px;
  overflow: hidden;
  border: 1px solid rgba(226, 232, 240, 0.94);
  border-radius: 26px;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.08), transparent 30%),
    #ffffff;
  box-shadow: 0 20px 56px rgba(15, 23, 42, 0.08);
}

.qy-cart-category-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 22px 18px;
  border-bottom: 1px solid #eef3f8;
}

.qy-cart-category-head span {
  display: block;
  color: #1263ff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.10em;
}

.qy-cart-category-head h3 {
  margin: 6px 0 0;
  color: #0f172a;
  font-size: 22px;
  line-height: 1.25;
  font-weight: 900;
}

.qy-cart-category-head > i {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: #1263ff;
  border-radius: 16px;
  background: #edf4ff;
  font-size: 22px;
}

.qy-cart-category-search {
  position: relative;
  margin: 18px 18px 12px;
}

.qy-cart-category-search input {
  width: 100%;
  min-height: 46px;
  padding: 0 46px 0 16px;
  color: #0f172a;
  border: 1px solid #dbe3ec;
  border-radius: 999px;
  outline: none;
  background: #f8fbff;
  font-size: 14px;
  font-weight: 800;
  transition: 0.18s ease;
}

.qy-cart-category-search input:focus {
  border-color: #93c5fd;
  background: #ffffff;
  box-shadow: 0 0 0 5px rgba(18, 99, 255, 0.08);
}

.qy-cart-category-search button {
  position: absolute;
  right: 5px;
  top: 5px;
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  color: #ffffff;
  border: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #1263ff, #20b8ff);
  box-shadow: 0 10px 22px rgba(18, 99, 255, 0.18);
}

.qy-cart-category-desc {
  display: grid;
  gap: 6px;
  margin: 0 18px 16px;
  padding: 14px;
  border: 1px solid #eef3f8;
  border-radius: 18px;
  background: #f8fbff;
}

.qy-cart-category-desc strong {
  color: #0f172a;
  font-size: 14px;
  line-height: 1.5;
  font-weight: 900;
}

.qy-cart-category-desc span {
  color: #64748b;
  font-size: 12px;
  line-height: 1.6;
}

.qy-cart-category-list {
  display: grid;
  gap: 8px;
  padding: 0 14px 18px;
}

.qy-cart-category-group {
  border: 1px solid transparent;
  border-radius: 18px;
  background: transparent;
  transition: 0.18s ease;
}

.qy-cart-category-group.is-open {
  border-color: #dbeafe;
  background: #f8fbff;
}

.qy-cart-category-first {
  width: 100%;
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 14px;
  color: #334155;
  border: 0;
  border-radius: 17px;
  background: transparent;
  font-size: 14px;
  font-weight: 900;
  text-align: left;
  transition: 0.18s ease;
}

.qy-cart-category-first:hover,
.qy-cart-category-group.is-open .qy-cart-category-first {
  color: #1263ff;
  background: #edf4ff;
}

.qy-cart-category-first i {
  position: relative;
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: rgba(18, 99, 255, 0.10);
}

.qy-cart-category-first i::before,
.qy-cart-category-first i::after {
  content: "";
  position: absolute;
  left: 5px;
  right: 5px;
  top: 8px;
  height: 2px;
  border-radius: 999px;
  background: #1263ff;
}

.qy-cart-category-first i::after {
  transform: rotate(90deg);
  transition: 0.18s ease;
}

.qy-cart-category-group.is-open .qy-cart-category-first i::after {
  transform: rotate(0deg);
}

.qy-cart-category-second {
  display: none;
  padding: 6px 8px 10px;
}

.qy-cart-category-group.is-open .qy-cart-category-second {
  display: grid;
  gap: 6px;
}

.qy-cart-category-second a {
  min-height: 38px;
  display: flex;
  align-items: center;
  padding: 0 12px 0 16px;
  color: #64748b;
  border-radius: 14px;
  font-size: 13px;
  font-weight: 850;
  text-decoration: none;
  transition: 0.18s ease;
}

.qy-cart-category-second a:hover,
.qy-cart-category-second a.is-active {
  color: #1263ff;
  background: #ffffff;
  box-shadow: 0 10px 22px rgba(18, 99, 255, 0.08);
  text-decoration: none;
}

.qy-cart-category-second a span {
  position: relative;
  padding-left: 14px;
}

.qy-cart-category-second a span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #93c5fd;
  transform: translateY(-50%);
}

.qy-cart-category-empty {
  min-height: 180px;
  display: grid;
  place-items: center;
  margin: 0 18px 18px;
  color: #64748b;
  border: 1px dashed #dbeafe;
  border-radius: 18px;
  background: #f8fbff;
  font-size: 14px;
  font-weight: 900;
}

@media (max-width: 991px) {
  .qy-cart-category-card {
    position: relative;
    top: auto;
    margin-bottom: 18px;
  }

  .qy-cart-product-main {
    width: 100%;
  }
}

@media (max-width: 768px) {
  body.qy-cart-mode .main-content {
    margin-left: 0 !important;
  }

  .qy-cart-category-head {
    padding: 18px;
  }

  .qy-cart-category-list {
    padding: 0 12px 14px;
  }
}



/* =========================================================
   qy-cart polish v2：购物车产品页精修版
   目标：隐藏用户中心菜单，左侧产品目录，右侧产品卡片更企业化
   ========================================================= */

body.qy-cart-mode .vertical-menu {
  display: none !important;
}

body.qy-cart-mode .main-content {
  margin-left: 0 !important;
}

body.qy-cart-mode #page-topbar {
  left: 0 !important;
}

.qy-cart-shop-page {
  padding: 18px 0 42px;
}

.qy-cart-shop-page::before {
  display: none;
}

.qy-cart-shop-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
  margin-bottom: 22px;
  padding: 30px 34px;
  border: 1px solid rgba(219, 234, 254, 0.95);
  border-radius: 30px;
  background:
    radial-gradient(circle at 90% 0, rgba(255, 255, 255, 0.24), transparent 30%),
    linear-gradient(135deg, #1263ff 0%, #0f63f5 52%, #20b8ff 100%);
  box-shadow: 0 24px 68px rgba(18, 99, 255, 0.22);
}

.qy-cart-shop-hero::before,
.qy-cart-shop-hero::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.13);
  pointer-events: none;
}

.qy-cart-shop-hero::before {
  width: 240px;
  height: 240px;
  right: -86px;
  top: -96px;
}

.qy-cart-shop-hero::after {
  width: 160px;
  height: 160px;
  left: 48%;
  bottom: -90px;
}

.qy-cart-shop-label {
  position: relative;
  z-index: 1;
  width: fit-content;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 12px;
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.13);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.qy-cart-shop-hero h1 {
  position: relative;
  z-index: 1;
  margin: 14px 0 0;
  color: #ffffff;
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.18;
  font-weight: 900;
  letter-spacing: -0.8px;
}

.qy-cart-shop-hero p {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin: 12px 0 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 15px;
  line-height: 1.8;
}

.qy-cart-shop-stats {
  position: relative;
  z-index: 1;
  min-width: 132px;
  padding: 18px 20px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.14);
  text-align: center;
  backdrop-filter: blur(12px);
}

.qy-cart-shop-stats strong {
  display: block;
  color: #ffffff;
  font-size: 34px;
  line-height: 1;
  font-weight: 900;
}

.qy-cart-shop-stats span {
  display: block;
  margin-top: 8px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  font-weight: 900;
}

.qy-cart-shop-layout {
  align-items: flex-start;
}

.qy-cart-sidebar-col {
  padding-right: 10px;
}

.qy-cart-product-main {
  min-width: 0;
  padding-left: 10px;
}

.qy-cart-category-card {
  position: sticky;
  top: 92px;
  overflow: hidden;
  border: 1px solid rgba(226, 232, 240, 0.94);
  border-radius: 28px;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.07), transparent 30%),
    #ffffff;
  box-shadow: 0 22px 62px rgba(15, 23, 42, 0.08);
}

.qy-cart-category-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 22px 18px;
  border-bottom: 1px solid #eef3f8;
}

.qy-cart-category-head span {
  display: block;
  color: #1263ff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.10em;
}

.qy-cart-category-head h3 {
  margin: 7px 0 0;
  color: #0f172a;
  font-size: 23px;
  line-height: 1.25;
  font-weight: 900;
}

.qy-cart-category-badge {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  color: #1263ff;
  border-radius: 18px;
  background: #edf4ff;
  font-size: 13px;
  font-weight: 900;
}

.qy-cart-category-search {
  position: relative;
  margin: 18px 18px 14px;
}

.qy-cart-category-search input {
  width: 100%;
  height: 48px;
  padding: 0 48px 0 17px;
  color: #0f172a;
  border: 1px solid #dbe3ec;
  border-radius: 999px;
  outline: none;
  background: #f8fbff;
  font-size: 14px;
  font-weight: 800;
  transition: 0.18s ease;
}

.qy-cart-category-search input:focus {
  border-color: #93c5fd;
  background: #ffffff;
  box-shadow: 0 0 0 5px rgba(18, 99, 255, 0.08);
}

.qy-cart-category-search button {
  position: absolute;
  right: 5px;
  top: 5px;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  color: #ffffff;
  border: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #1263ff, #20b8ff);
  box-shadow: 0 10px 22px rgba(18, 99, 255, 0.18);
}

.qy-cart-category-list {
  display: grid;
  gap: 9px;
  padding: 0 14px 18px;
}

.qy-cart-category-group {
  border: 1px solid transparent;
  border-radius: 20px;
  background: transparent;
  transition: 0.18s ease;
}

.qy-cart-category-group.is-open {
  border-color: #dbeafe;
  background: #f8fbff;
}

.qy-cart-category-first {
  width: 100%;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 15px;
  color: #334155;
  border: 0;
  border-radius: 19px;
  background: transparent;
  font-size: 15px;
  font-weight: 900;
  text-align: left;
  transition: 0.18s ease;
}

.qy-cart-category-first:hover,
.qy-cart-category-group.is-open .qy-cart-category-first {
  color: #1263ff;
  background: #edf4ff;
}

.qy-cart-category-first i {
  position: relative;
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: rgba(18, 99, 255, 0.10);
}

.qy-cart-category-first i::before,
.qy-cart-category-first i::after {
  content: "";
  position: absolute;
  left: 6px;
  right: 6px;
  top: 9px;
  height: 2px;
  border-radius: 999px;
  background: #1263ff;
}

.qy-cart-category-first i::after {
  transform: rotate(90deg);
  transition: 0.18s ease;
}

.qy-cart-category-group.is-open .qy-cart-category-first i::after {
  transform: rotate(0deg);
}

.qy-cart-category-second {
  display: none;
  padding: 6px 8px 11px;
}

.qy-cart-category-group.is-open .qy-cart-category-second {
  display: grid;
  gap: 7px;
}

.qy-cart-category-second a {
  min-height: 40px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  color: #64748b;
  border-radius: 15px;
  font-size: 13.5px;
  font-weight: 850;
  text-decoration: none;
  transition: 0.18s ease;
}

.qy-cart-category-second a:hover,
.qy-cart-category-second a.is-active {
  color: #1263ff;
  background: #ffffff;
  box-shadow: 0 10px 22px rgba(18, 99, 255, 0.08);
  text-decoration: none;
}

.qy-cart-category-second a span {
  position: relative;
  padding-left: 16px;
}

.qy-cart-category-second a span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #93c5fd;
  transform: translateY(-50%);
}

.qy-cart-category-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 18px 18px;
  padding: 13px 14px;
  border: 1px solid #eef3f8;
  border-radius: 18px;
  background: #f8fbff;
}

.qy-cart-category-footer span {
  color: #64748b;
  font-size: 13px;
  font-weight: 800;
}

.qy-cart-category-footer a {
  color: #1263ff;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
}

.qy-cart-product-panel {
  overflow: hidden;
  border: 1px solid rgba(226, 232, 240, 0.94);
  border-radius: 28px;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.06), transparent 30%),
    #ffffff;
  box-shadow: 0 22px 62px rgba(15, 23, 42, 0.08);
}

.qy-cart-product-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px 26px 20px;
  border-bottom: 1px solid #eef3f8;
}

.qy-cart-product-panel-head h2 {
  margin: 0;
  color: #0f172a;
  font-size: 24px;
  line-height: 1.25;
  font-weight: 900;
}

.qy-cart-product-panel-head p {
  margin: 8px 0 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.7;
}

.qy-cart-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding: 22px;
}

.qy-cart-product-card {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  border: 1px solid #eef3f8;
  border-radius: 24px;
  background: #ffffff;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
  transition: 0.18s ease;
}

.qy-cart-product-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: linear-gradient(90deg, #1263ff, #20b8ff);
  opacity: 0;
  transition: 0.18s ease;
}

.qy-cart-product-card:hover {
  transform: translateY(-4px);
  border-color: #cfe0ff;
  box-shadow: 0 22px 48px rgba(18, 99, 255, 0.12);
}

.qy-cart-product-card:hover::before {
  opacity: 1;
}

.qy-cart-product-card-head {
  display: flex;
  align-items: center;
  gap: 13px;
  padding: 20px 18px 14px;
}

.qy-cart-product-icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: #ffffff;
  border-radius: 18px;
  background: linear-gradient(135deg, #1263ff, #20b8ff);
  box-shadow: 0 14px 30px rgba(18, 99, 255, 0.18);
  font-size: 17px;
  font-weight: 900;
}

.qy-cart-product-card h3 {
  margin: 0;
  color: #0f172a;
  font-size: 18px;
  line-height: 1.35;
  font-weight: 900;
}

.qy-cart-stock {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  margin-top: 6px;
  padding: 0 8px;
  color: #1263ff;
  border-radius: 999px;
  background: #edf4ff;
  font-size: 12px;
  font-weight: 900;
}

.qy-cart-product-desc {
  flex: 1;
  padding: 0 18px;
}

.qy-cart-product-desc pre {
  max-height: 112px;
  overflow: hidden;
  margin: 0;
  color: #64748b;
  font-family: inherit;
  font-size: 13px;
  line-height: 1.75;
  white-space: pre-wrap;
}

.qy-cart-product-price {
  display: grid;
  gap: 7px;
  margin: 18px;
  padding: 16px;
  border-radius: 18px;
  background: #f8fbff;
}

.qy-cart-product-price > div {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px;
}

.qy-cart-product-price span {
  color: #64748b;
  font-size: 12px;
  font-weight: 900;
}

.qy-cart-product-price strong {
  color: #1263ff;
  font-size: 24px;
  line-height: 1;
  font-weight: 900;
}

.qy-cart-product-price em {
  color: #64748b;
  font-style: normal;
  font-size: 13px;
  font-weight: 800;
}

.qy-cart-product-price small {
  color: #94a3b8;
  font-size: 12px;
  line-height: 1.5;
}

.qy-cart-buy-btn {
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 18px 18px;
  padding: 0 18px;
  color: #ffffff !important;
  border-radius: 999px;
  background: linear-gradient(135deg, #1263ff, #20b8ff);
  box-shadow: 0 16px 34px rgba(18, 99, 255, 0.22);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none !important;
  transition: 0.18s ease;
}

.qy-cart-buy-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 44px rgba(18, 99, 255, 0.28);
}

.qy-cart-buy-btn i {
  font-style: normal;
  font-size: 18px;
}

.qy-cart-empty-products {
  min-height: 320px;
  display: grid;
  place-items: center;
  padding: 40px;
  text-align: center;
}

.qy-cart-empty-products div {
  color: #0f172a;
  font-size: 24px;
  font-weight: 900;
}

.qy-cart-empty-products p {
  margin: 10px 0 0;
  color: #64748b;
}

@media (max-width: 1380px) {
  .qy-cart-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .qy-cart-shop-hero {
    grid-template-columns: 1fr;
    padding: 26px;
  }

  .qy-cart-sidebar-col,
  .qy-cart-product-main {
    padding-left: 15px;
    padding-right: 15px;
  }

  .qy-cart-category-card {
    position: relative;
    top: auto;
    margin-bottom: 18px;
  }
}

@media (max-width: 640px) {
  .qy-cart-shop-hero {
    border-radius: 24px;
    padding: 22px;
  }

  .qy-cart-shop-stats {
    display: none;
  }

  .qy-cart-product-panel,
  .qy-cart-category-card {
    border-radius: 22px;
  }

  .qy-cart-product-grid {
    grid-template-columns: 1fr;
    padding: 16px;
  }

  .qy-cart-product-panel-head {
    padding: 20px;
  }
}



/* =========================================================
   qy-cart luansui-like v3：参考峦穗云产品页的选购布局
   ========================================================= */

body.qy-cart-mode .vertical-menu {
  display: none !important;
}

body.qy-cart-mode .main-content {
  margin-left: 0 !important;
}

body.qy-cart-mode #page-topbar {
  left: 0 !important;
}

.qy-cart-ls-page {
  padding: 10px 0 46px;
  background:
    radial-gradient(circle at 8% 0, rgba(18, 99, 255, 0.06), transparent 28%),
    linear-gradient(180deg, #f8fbff 0%, #ffffff 42%);
}

.qy-cart-ls-page::before {
  display: none;
}

.qy-cart-ls-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 22px;
  padding: 26px 30px;
  border: 1px solid #e2e8f0;
  border-radius: 26px;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.08), transparent 30%),
    #ffffff;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.06);
}

.qy-cart-ls-back {
  min-width: 62px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1263ff;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: #edf4ff;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none !important;
}

.qy-cart-ls-head h1 {
  margin: 0;
  color: #0f172a;
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.18;
  font-weight: 900;
  letter-spacing: -0.6px;
}

.qy-cart-ls-head p {
  max-width: 820px;
  margin: 12px 0 0;
  color: #64748b;
  font-size: 15px;
  line-height: 1.8;
}

.qy-cart-ls-layout {
  align-items: flex-start;
}

.qy-cart-ls-sidebar-col {
  padding-right: 10px;
}

.qy-cart-ls-main {
  padding-left: 10px;
}

.qy-cart-ls-category {
  position: sticky;
  top: 92px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  border-radius: 24px;
  background: #ffffff;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.06);
}

.qy-cart-ls-category-title {
  padding: 22px 20px 16px;
  border-bottom: 1px solid #eef3f8;
}

.qy-cart-ls-category-title h3 {
  margin: 0;
  color: #0f172a;
  font-size: 22px;
  line-height: 1.25;
  font-weight: 900;
}

.qy-cart-ls-category-title span {
  display: block;
  margin-top: 8px;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 800;
}

.qy-cart-ls-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 58px;
  gap: 8px;
  padding: 16px;
  border-bottom: 1px solid #eef3f8;
}

.qy-cart-ls-search input {
  min-width: 0;
  height: 42px;
  padding: 0 13px;
  color: #0f172a;
  border: 1px solid #dbe3ec;
  border-radius: 12px;
  outline: none;
  background: #f8fbff;
  font-size: 13px;
  font-weight: 800;
}

.qy-cart-ls-search input:focus {
  border-color: #93c5fd;
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(18, 99, 255, 0.08);
}

.qy-cart-ls-search button {
  height: 42px;
  color: #ffffff;
  border: 0;
  border-radius: 12px;
  background: linear-gradient(135deg, #1263ff, #20b8ff);
  font-size: 13px;
  font-weight: 900;
}

.qy-cart-ls-category-list {
  display: grid;
  gap: 0;
  padding: 10px;
}

.qy-cart-ls-category-group {
  border-radius: 16px;
}

.qy-cart-ls-first {
  width: 100%;
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 14px;
  color: #334155;
  border: 0;
  border-radius: 14px;
  background: transparent;
  font-size: 14px;
  font-weight: 900;
  text-align: left;
}

.qy-cart-ls-first:hover,
.qy-cart-ls-category-group.is-open .qy-cart-ls-first {
  color: #1263ff;
  background: #edf4ff;
}

.qy-cart-ls-first i {
  position: relative;
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.qy-cart-ls-first i::before,
.qy-cart-ls-first i::after {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  top: 8px;
  height: 2px;
  border-radius: 999px;
  background: #1263ff;
}

.qy-cart-ls-first i::after {
  transform: rotate(90deg);
  transition: 0.18s ease;
}

.qy-cart-ls-category-group.is-open .qy-cart-ls-first i::after {
  transform: rotate(0deg);
}

.qy-cart-ls-second {
  display: none;
  padding: 4px 8px 10px;
}

.qy-cart-ls-category-group.is-open .qy-cart-ls-second {
  display: grid;
  gap: 4px;
}

.qy-cart-ls-second a {
  min-height: 38px;
  display: flex;
  align-items: center;
  padding: 0 12px 0 24px;
  color: #64748b;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 850;
  text-decoration: none !important;
}

.qy-cart-ls-second a:hover,
.qy-cart-ls-second a.is-active {
  color: #1263ff;
  background: #f8fbff;
}

.qy-cart-ls-category-empty {
  min-height: 160px;
  display: grid;
  place-items: center;
  margin: 14px;
  color: #64748b;
  border: 1px dashed #dbeafe;
  border-radius: 16px;
  background: #f8fbff;
  font-weight: 900;
}

.qy-cart-ls-notice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
  padding: 18px 20px;
  border: 1px solid #dbeafe;
  border-radius: 22px;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.07), transparent 30%),
    #ffffff;
  box-shadow: 0 14px 38px rgba(15, 23, 42, 0.05);
}

.qy-cart-ls-notice strong {
  display: block;
  color: #0f172a;
  font-size: 16px;
  font-weight: 900;
}

.qy-cart-ls-notice span {
  display: block;
  margin-top: 6px;
  color: #64748b;
  font-size: 13px;
  line-height: 1.7;
}

.qy-cart-ls-notice a {
  min-width: 100px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1263ff;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: #edf4ff;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none !important;
}

.qy-cart-ls-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.qy-cart-ls-card {
  position: relative;
  overflow: hidden;
  display: flex;
  min-height: 100%;
  flex-direction: column;
  border: 1px solid #e2e8f0;
  border-radius: 22px;
  background: #ffffff;
  box-shadow: 0 16px 42px rgba(15, 23, 42, 0.055);
  transition: 0.18s ease;
}

.qy-cart-ls-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, #1263ff, #20b8ff);
  opacity: 0;
  transition: 0.18s ease;
}

.qy-cart-ls-card:hover {
  transform: translateY(-4px);
  border-color: #cfe0ff;
  box-shadow: 0 24px 54px rgba(18, 99, 255, 0.12);
}

.qy-cart-ls-card:hover::before {
  opacity: 1;
}

.qy-cart-ls-card-top {
  min-height: 92px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 22px 20px 14px;
}

.qy-cart-ls-card h2 {
  margin: 0;
  color: #0f172a;
  font-size: 18px;
  line-height: 1.35;
  font-weight: 900;
}

.qy-cart-ls-card-top span {
  display: block;
  margin-top: 8px;
  color: #64748b;
  font-size: 12px;
  font-weight: 850;
}

.qy-cart-ls-tag {
  min-width: 42px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1263ff;
  border-radius: 999px;
  background: #edf4ff;
  font-size: 12px;
  font-weight: 900;
}

.qy-cart-ls-spec {
  flex: 1;
  margin: 0 20px;
  padding: 15px 16px;
  border-radius: 16px;
  background: #f8fbff;
}

.qy-cart-ls-spec pre {
  min-height: 104px;
  max-height: 150px;
  overflow: hidden;
  margin: 0;
  color: #475569;
  font-family: inherit;
  font-size: 13px;
  line-height: 1.8;
  white-space: pre-wrap;
}

.qy-cart-ls-line {
  height: 1px;
  margin: 18px 20px 0;
  background: #eef3f8;
}

.qy-cart-ls-service {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 20px;
  padding: 14px 0;
}

.qy-cart-ls-service span {
  color: #64748b;
  font-size: 13px;
  font-weight: 850;
}

.qy-cart-ls-service strong {
  color: #0f172a;
  font-size: 13px;
  font-weight: 900;
}

.qy-cart-ls-bottom {
  display: grid;
  gap: 14px;
  margin-top: auto;
  padding: 0 20px 20px;
}

.qy-cart-ls-price {
  display: grid;
  gap: 4px;
}

.qy-cart-ls-price strong {
  color: #1263ff;
  font-size: 26px;
  line-height: 1;
  font-weight: 900;
}

.qy-cart-ls-price em {
  color: #64748b;
  font-style: normal;
  font-size: 13px;
  font-weight: 850;
}

.qy-cart-ls-price small {
  color: #94a3b8;
  font-size: 12px;
  line-height: 1.6;
}

.qy-cart-ls-buy {
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff !important;
  border-radius: 999px;
  background: linear-gradient(135deg, #1263ff, #20b8ff);
  box-shadow: 0 16px 34px rgba(18, 99, 255, 0.20);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none !important;
  transition: 0.18s ease;
}

.qy-cart-ls-buy:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 44px rgba(18, 99, 255, 0.26);
}

.qy-cart-ls-empty {
  min-height: 320px;
  display: grid;
  place-items: center;
  padding: 40px;
  border: 1px dashed #dbeafe;
  border-radius: 22px;
  background: #ffffff;
  text-align: center;
}

.qy-cart-ls-empty strong {
  color: #0f172a;
  font-size: 24px;
  font-weight: 900;
}

.qy-cart-ls-empty span {
  margin-top: 8px;
  color: #64748b;
}

@media (max-width: 1380px) {
  .qy-cart-ls-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .qy-cart-ls-head {
    grid-template-columns: 1fr;
  }

  .qy-cart-ls-sidebar-col,
  .qy-cart-ls-main {
    padding-left: 15px;
    padding-right: 15px;
  }

  .qy-cart-ls-category {
    position: relative;
    top: auto;
    margin-bottom: 18px;
  }
}

@media (max-width: 640px) {
  .qy-cart-ls-head {
    padding: 22px;
    border-radius: 22px;
  }

  .qy-cart-ls-notice {
    display: block;
  }

  .qy-cart-ls-notice a {
    width: 100%;
    margin-top: 14px;
  }

  .qy-cart-ls-grid {
    grid-template-columns: 1fr;
  }
}



/* =========================================================
   qy-cart final：web common header + 商品描述表格自适应
   ========================================================= */

/* 不要用户中心默认顶部和左侧菜单，购物车使用 qiyueyun web header */
body.qy-cart-mode .vertical-menu,
body.qy-cart-mode #page-topbar {
  display: none !important;
}

body.qy-cart-mode .main-content {
  margin-left: 0 !important;
}

body.qy-cart-mode .page-content {
  padding-top: 0 !important;
}

body.qy-cart-mode .container-fluid {
  max-width: 1440px;
}

/* web header 放到购物车顶部时，避免被后台布局压缩 */
.qy-cart-web-header {
  position: relative;
  z-index: 30;
  margin: 0 calc(50% - 50vw) 24px;
  background: #ffffff;
}

.qy-cart-web-header .qy-header {
  position: relative;
  z-index: 30;
}

.qy-cart-web-header .qy-navbar {
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04);
}

.qy-cart-web-header .qy-container {
  width: min(1440px, calc(100% - 40px));
}

/* 同一行卡片高度统一 */
.qy-cart-ls-grid,
.qy-cart-product-grid {
  align-items: stretch;
}

.qy-cart-ls-card,
.qy-cart-product-card {
  height: 100%;
}

.qy-cart-ls-bottom,
.qy-cart-product-price {
  margin-top: auto;
}

/* 商品描述区自适应：支持 description 里直接输出 table */
.qy-cart-ls-spec,
.qy-cart-product-desc {
  overflow: visible;
}

.qy-cart-ls-spec pre,
.qy-cart-product-desc pre {
  max-height: none !important;
  min-height: 0 !important;
  overflow: visible !important;
  margin: 0 !important;
  color: #475569;
  font-family: inherit !important;
  font-size: 13px;
  line-height: 1.75;
  white-space: normal !important;
  word-break: break-word;
}

/* description 内表格 */
.qy-cart-ls-spec table,
.qy-cart-product-desc table,
.qy-cart-ls-spec .tftable,
.qy-cart-product-desc .tftable {
  width: 100% !important;
  max-width: 100% !important;
  table-layout: fixed;
  border-collapse: separate !important;
  border-spacing: 0 8px !important;
  margin: 0 !important;
  background: transparent !important;
}

.qy-cart-ls-spec table tbody,
.qy-cart-product-desc table tbody {
  width: 100%;
}

.qy-cart-ls-spec table tr,
.qy-cart-product-desc table tr {
  display: table-row;
}

.qy-cart-ls-spec table td,
.qy-cart-product-desc table td {
  padding: 8px 10px !important;
  border: 0 !important;
  border-radius: 10px;
  background: #ffffff;
  color: #334155 !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  vertical-align: middle !important;
  word-break: break-word;
}

.qy-cart-ls-spec table td:first-child,
.qy-cart-product-desc table td:first-child {
  width: 74px;
  color: #64748b !important;
  background: #edf4ff;
  text-align: center;
  white-space: nowrap;
}

.qy-cart-ls-spec table td:first-child b,
.qy-cart-product-desc table td:first-child b {
  color: #1263ff;
  font-weight: 900;
}

.qy-cart-ls-spec .qisuidc_adv,
.qy-cart-product-desc .qisuidc_adv {
  min-height: 22px;
  display: inline-flex;
  align-items: center;
  margin-left: 6px;
  padding: 0 7px;
  color: #1263ff;
  border-radius: 999px;
  background: #edf4ff;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.qy-cart-ls-spec .qisuidc_bq,
.qy-cart-product-desc .qisuidc_bq {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  margin-top: 8px;
  padding: 0 10px;
  color: #1263ff;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: #ffffff;
  font-size: 12px;
  font-weight: 900;
}

.qy-cart-ls-spec hr,
.qy-cart-product-desc hr {
  margin: 12px 0 0 !important;
  border: 0;
  border-top: 1px solid #e2e8f0;
}

@media (max-width: 640px) {
  .qy-cart-web-header .qy-container {
    width: min(100% - 28px, 1440px);
  }

  .qy-cart-ls-spec table,
  .qy-cart-product-desc table {
    table-layout: auto;
  }

  .qy-cart-ls-spec table td,
  .qy-cart-product-desc table td {
    padding: 7px 8px !important;
    font-size: 12px !important;
  }

  .qy-cart-ls-spec table td:first-child,
  .qy-cart-product-desc table td:first-child {
    width: 62px;
  }
}



/* =========================================================
   qy-cart final：隐藏用户中心默认面包屑/页面标题
   对应：购物车 / 用户中心 > 购物车 这一块
   ========================================================= */
body.qy-cart-mode .page-content > .container-fluid:first-child,
body.qy-cart-mode .page-title-box,
body.qy-cart-mode .page-title-right,
body.qy-cart-mode .breadcrumb {
  display: none !important;
}

body.qy-cart-mode .page-content {
  padding-top: 0 !important;
}

body.qy-cart-mode .page-content > .container-fluid {
  padding-top: 0 !important;
}


/* =========================================================
   qy-cart configure v4：产品配置页选配按钮精修
   作用范围：.qy-cart-configure-page
   ========================================================= */

.qy-cart-configure-page {
  padding-bottom: 48px;
}

.qy-cart-configure-page > form > .row {
  align-items: flex-start;
}

.qy-cart-configure-page .col-xl-8 > .card:first-child {
  overflow: hidden;
  border: 1px solid #dbeafe !important;
  border-radius: 28px 28px 0 0 !important;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.09), transparent 34%),
    #ffffff !important;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.06) !important;
}

.qy-cart-configure-page .col-xl-8 > .card:first-child .card-body {
  padding: 26px 28px !important;
}

.qy-cart-configure-page .col-xl-8 > .card:first-child .card-title {
  margin: 0 !important;
  color: #0f172a !important;
  font-size: 28px !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
  letter-spacing: -0.4px;
}

.qy-cart-configure-page .col-xl-8 > .card:nth-child(2) {
  overflow: hidden;
  border: 1px solid #e2e8f0 !important;
  border-top: 0 !important;
  border-radius: 0 0 28px 28px !important;
  background: #ffffff !important;
  box-shadow: 0 22px 62px rgba(15, 23, 42, 0.08) !important;
}

.qy-cart-configure-page .col-xl-8 > .card:nth-child(2) > .card-body {
  padding: 8px 28px 30px !important;
}

.qy-cart-configure-page .configureproduct,
.qy-cart-configure-page .form-group.row {
  position: relative;
  align-items: flex-start !important;
  margin: 0 !important;
  padding: 22px 0 !important;
  border-bottom: 1px solid #eef3f8;
}

.qy-cart-configure-page .configureproduct:last-child,
.qy-cart-configure-page .form-group.row:last-child {
  border-bottom: 0;
}

.qy-cart-configure-page .col-form-label {
  min-height: 40px;
  display: flex !important;
  align-items: center;
  color: #0f172a !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1.4 !important;
}

.qy-cart-configure-page .col-form-label::before {
  content: "";
  width: 7px;
  height: 18px;
  flex: 0 0 auto;
  margin-right: 10px;
  border-radius: 999px;
  background: linear-gradient(180deg, #1263ff, #20b8ff);
}

.qy-cart-configure-page .bx.bxs-help-circle {
  margin-left: 6px;
  color: #1263ff !important;
}

.qy-cart-configure-page .btn-group-toggle,
.qy-cart-configure-page .btn-custom-group,
.qy-cart-configure-page .cycle,
.qy-cart-configure-page .justify-content-start {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: stretch !important;
  width: 100% !important;
}

.qy-cart-configure-page .btn-group,
.qy-cart-configure-page .btn-group-toggle {
  vertical-align: top !important;
}

.qy-cart-configure-page .btn-group-toggle > .btn,
.qy-cart-configure-page .btn-group-toggle label.btn,
.qy-cart-configure-page .btn-custom,
.qy-cart-configure-page label.btn.btn-primary,
.qy-cart-configure-page label.btn.btn-sm,
.qy-cart-configure-page .cycle label.btn {
  position: relative !important;
  min-width: 94px !important;
  min-height: 42px !important;
  height: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  margin: 0 !important;
  padding: 10px 16px !important;
  color: #334155 !important;
  border: 1px solid #dbe3ec !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.035) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  transition: 0.18s ease !important;
}

.qy-cart-configure-page .btn-group-toggle > .btn:hover,
.qy-cart-configure-page .btn-group-toggle label.btn:hover,
.qy-cart-configure-page .btn-custom:hover,
.qy-cart-configure-page label.btn.btn-primary:hover,
.qy-cart-configure-page label.btn.btn-sm:hover,
.qy-cart-configure-page .cycle label.btn:hover {
  color: #1263ff !important;
  border-color: #bfdbfe !important;
  background: #f8fbff !important;
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(18, 99, 255, 0.10) !important;
}

.qy-cart-configure-page .btn-group-toggle > .btn.active,
.qy-cart-configure-page .btn-group-toggle label.btn.active,
.qy-cart-configure-page .btn-custom-group .active,
.qy-cart-configure-page .cycle label.btn.active,
.qy-cart-configure-page label.btn.btn-primary.active,
.qy-cart-configure-page label.btn.btn-sm.active {
  color: #1263ff !important;
  border-color: #1263ff !important;
  background:
    radial-gradient(circle at 100% 0, rgba(32, 184, 255, 0.16), transparent 36%),
    #edf4ff !important;
  box-shadow: 0 16px 32px rgba(18, 99, 255, 0.14) !important;
}

.qy-cart-configure-page .btn-group-toggle > .btn.active::after,
.qy-cart-configure-page .btn-group-toggle label.btn.active::after,
.qy-cart-configure-page .btn-custom-group .active::after,
.qy-cart-configure-page .cycle label.btn.active::after,
.qy-cart-configure-page label.btn.btn-primary.active::after,
.qy-cart-configure-page label.btn.btn-sm.active::after {
  content: "✓";
  position: absolute;
  right: -1px;
  top: -1px;
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  color: #ffffff;
  border-radius: 0 15px 0 12px;
  background: linear-gradient(135deg, #1263ff, #20b8ff);
  font-size: 12px;
  font-weight: 900;
}

.qy-cart-configure-page .btn-group-toggle input[type="radio"],
.qy-cart-configure-page .btn-group-toggle input[type="checkbox"],
.qy-cart-configure-page label.btn input {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.qy-cart-configure-page .cycle label.btn,
.qy-cart-configure-page .cycle .btn-custom {
  min-width: 122px !important;
  min-height: 48px !important;
  padding: 13px 18px !important;
  border-radius: 18px !important;
}

.qy-cart-configure-page .cycle-select-discount {
  top: -9px !important;
  right: 10px !important;
  height: 22px !important;
  display: inline-flex !important;
  align-items: center;
  padding: 0 8px !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #ef4444, #fb7185) !important;
  box-shadow: 0 8px 18px rgba(239, 68, 68, 0.18);
  font-size: 12px !important;
  line-height: 22px !important;
  font-weight: 900 !important;
}

.qy-cart-configure-page .form-check {
  margin: 0 10px 10px 0 !important;
  padding-left: 0 !important;
}

.qy-cart-configure-page .form-check-input {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.qy-cart-configure-page .form-check-label {
  min-height: 42px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  color: #334155;
  border: 1px solid #dbe3ec;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.035);
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  transition: 0.18s ease;
}

.qy-cart-configure-page .form-check-input:checked + .form-check-label,
.qy-cart-configure-page .form-check-label:hover {
  color: #1263ff;
  border-color: #1263ff;
  background: #edf4ff;
}

.qy-cart-configure-page .custom-control {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  margin: 0 10px 10px 0 !important;
  padding-left: 0 !important;
}

.qy-cart-configure-page .custom-control-label {
  min-height: 42px;
  display: inline-flex !important;
  align-items: center;
  padding: 10px 16px 10px 42px;
  color: #334155;
  border: 1px solid #dbe3ec;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.035);
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
}

.qy-cart-configure-page .custom-control-label::before {
  left: 14px !important;
  top: 50% !important;
  width: 18px !important;
  height: 18px !important;
  border-color: #bfdbfe !important;
  border-radius: 6px !important;
  background: #edf4ff !important;
  transform: translateY(-50%);
}

.qy-cart-configure-page .custom-control-label::after {
  left: 14px !important;
  top: 50% !important;
  width: 18px !important;
  height: 18px !important;
  transform: translateY(-50%);
}

.qy-cart-configure-page .custom-control-input:checked ~ .custom-control-label {
  color: #1263ff;
  border-color: #1263ff;
  background: #edf4ff;
}

.qy-cart-configure-page .custom-control-input:checked ~ .custom-control-label::before {
  border-color: #1263ff !important;
  background: #1263ff !important;
}

.qy-cart-configure-page .bootstrap-select {
  width: 100% !important;
}

.qy-cart-configure-page .bootstrap-select > .dropdown-toggle,
.qy-cart-configure-page .selectpicker + .dropdown-toggle {
  min-height: 46px !important;
  padding: 0 16px !important;
  color: #334155 !important;
  border: 1px solid #dbe3ec !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.035) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

.qy-cart-configure-page .bootstrap-select > .dropdown-toggle:hover,
.qy-cart-configure-page .bootstrap-select.show > .dropdown-toggle {
  color: #1263ff !important;
  border-color: #1263ff !important;
  background: #edf4ff !important;
}

.qy-cart-configure-page .dropdown-menu {
  overflow: hidden;
  border: 1px solid #dbeafe !important;
  border-radius: 18px !important;
  box-shadow: 0 22px 54px rgba(15, 23, 42, 0.14) !important;
}

.qy-cart-configure-page .dropdown-item {
  min-height: 38px;
  color: #334155 !important;
  font-weight: 850 !important;
}

.qy-cart-configure-page .dropdown-item:hover,
.qy-cart-configure-page .dropdown-item.active,
.qy-cart-configure-page .dropdown-item:active {
  color: #1263ff !important;
  background: #edf4ff !important;
}

.qy-cart-configure-page .form-control {
  min-height: 46px !important;
  border: 1px solid #dbe3ec !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  box-shadow: none !important;
  color: #0f172a !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}

.qy-cart-configure-page .form-control:focus {
  border-color: #1263ff !important;
  box-shadow: 0 0 0 5px rgba(18, 99, 255, 0.08) !important;
}

.qy-cart-configure-page input[type='range'],
.qy-cart-configure-page .configoption_range {
  height: 8px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, #1263ff, #20b8ff) !important;
}

.qy-cart-configure-page input[type="range"]::-webkit-slider-thumb {
  width: 22px !important;
  height: 22px !important;
  border: 5px solid #ffffff !important;
  border-radius: 50% !important;
  background: #1263ff !important;
  box-shadow: 0 8px 18px rgba(18, 99, 255, 0.25) !important;
}

.qy-cart-configure-page input[type="range"]::-moz-range-thumb {
  width: 22px !important;
  height: 22px !important;
  border: 5px solid #ffffff !important;
  border-radius: 50% !important;
  background: #1263ff !important;
  box-shadow: 0 8px 18px rgba(18, 99, 255, 0.25) !important;
}

.qy-cart-configure-page .configoption_range_val {
  max-width: 92px !important;
  min-width: 72px !important;
  margin-left: 14px !important;
  text-align: center;
}

.qy-cart-configure-page .col-xl-4 {
  position: sticky;
  top: 92px;
}

.qy-cart-configure-page .col-xl-4 .card {
  overflow: hidden;
  border: 1px solid #dbeafe !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at 100% 0, rgba(18, 99, 255, 0.08), transparent 32%),
    #ffffff !important;
  box-shadow: 0 22px 62px rgba(15, 23, 42, 0.08) !important;
}

.qy-cart-configure-page .col-xl-4 .card-title {
  margin-bottom: 18px !important;
  color: #0f172a !important;
  font-size: 20px !important;
  font-weight: 900 !important;
}

.qy-cart-configure-page .configoption_total {
  color: #475569;
}

.qy-cart-configure-page button[type="submit"],
.qy-cart-configure-page .btn-block,
.qy-cart-configure-page .btn-primary:not(label) {
  min-height: 46px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #1263ff, #20b8ff) !important;
  box-shadow: 0 16px 34px rgba(18, 99, 255, 0.22) !important;
  color: #ffffff !important;
  font-weight: 900 !important;
}

@media (max-width: 1199px) {
  .qy-cart-configure-page .col-xl-4 {
    position: relative;
    top: auto;
    margin-top: 18px;
  }
}

@media (max-width: 768px) {
  .qy-cart-configure-page .col-xl-8 > .card:first-child .card-title {
    font-size: 23px !important;
  }

  .qy-cart-configure-page .col-xl-8 > .card:first-child .card-body,
  .qy-cart-configure-page .col-xl-8 > .card:nth-child(2) > .card-body {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .qy-cart-configure-page .configureproduct,
  .qy-cart-configure-page .form-group.row {
    padding: 18px 0 !important;
  }

  .qy-cart-configure-page .col-form-label {
    margin-bottom: 10px;
  }

  .qy-cart-configure-page .btn-group-toggle > .btn,
  .qy-cart-configure-page .btn-group-toggle label.btn,
  .qy-cart-configure-page .btn-custom,
  .qy-cart-configure-page label.btn.btn-primary,
  .qy-cart-configure-page label.btn.btn-sm,
  .qy-cart-configure-page .cycle label.btn {
    min-width: calc(50% - 5px) !important;
    flex: 1 1 calc(50% - 5px) !important;
  }

  .qy-cart-configure-page .configoption_range_val {
    max-width: 78px !important;
  }
}

@media (max-width: 420px) {
  .qy-cart-configure-page .btn-group-toggle > .btn,
  .qy-cart-configure-page .btn-group-toggle label.btn,
  .qy-cart-configure-page .btn-custom,
  .qy-cart-configure-page label.btn.btn-primary,
  .qy-cart-configure-page label.btn.btn-sm,
  .qy-cart-configure-page .cycle label.btn {
    min-width: 100% !important;
    flex-basis: 100% !important;
  }
}


/* =========================================================
   qy-cart configure v5：修复选配按钮尺寸、镜像下拉错位
   ========================================================= */

/* 配置项左标题 + 右内容，保持一行结构，不让控件乱撑 */
.qy-cart-configure-page .configureproduct,
.qy-cart-configure-page .form-group.row {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 18px !important;
  padding: 22px 0 !important;
}

.qy-cart-configure-page .configureproduct > label.col-form-label,
.qy-cart-configure-page .form-group.row > label.col-form-label {
  flex: 0 0 128px !important;
  width: 128px !important;
  max-width: 128px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin: 0 !important;
}

/* 右侧内容区统一，不继承 Bootstrap 的 col 宽度导致挤压 */
.qy-cart-configure-page .configureproduct > .col-md-10,
.qy-cart-configure-page .form-group.row > .col-md-10 {
  flex: 1 1 auto !important;
  width: auto !important;
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.qy-cart-configure-page .configureproduct > .col-md-3,
.qy-cart-configure-page .form-group.row > .col-md-3,
.qy-cart-configure-page .configureproduct > .col-md-2,
.qy-cart-configure-page .form-group.row > .col-md-2,
.qy-cart-configure-page .configureproduct > .col-8,
.qy-cart-configure-page .form-group.row > .col-8 {
  flex: 0 0 220px !important;
  width: 220px !important;
  max-width: 220px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* 操作系统这种两个下拉框并排，保持统一宽度 */
.qy-cart-configure-page .configureproduct > .col-md-2 + .col-md-3,
.qy-cart-configure-page .form-group.row > .col-md-2 + .col-md-3 {
  margin-left: 10px !important;
}

/* 按钮区域：只换行，不拉伸，大小统一 */
.qy-cart-configure-page .btn-group-toggle,
.qy-cart-configure-page .btn-custom-group,
.qy-cart-configure-page .cycle,
.qy-cart-configure-page .justify-content-start {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  width: 100% !important;
}

/* 普通选配按钮统一尺寸：CPU/内存/系统盘/数据盘/DDOS/内网IP等 */
.qy-cart-configure-page .btn-group-toggle > label.btn,
.qy-cart-configure-page .btn-group-toggle > .btn,
.qy-cart-configure-page label.btn.btn-primary,
.qy-cart-configure-page label.btn.btn-sm,
.qy-cart-configure-page .btn-custom {
  flex: 0 0 118px !important;
  width: 118px !important;
  min-width: 118px !important;
  max-width: 118px !important;
  min-height: 44px !important;
  height: 44px !important;
  padding: 0 12px !important;
  overflow: visible !important;
  white-space: nowrap !important;
  text-align: center !important;
}

/* 周期按钮单独略宽，但也统一 */
.qy-cart-configure-page .cycle > label.btn,
.qy-cart-configure-page .cycle .btn-custom {
  flex: 0 0 130px !important;
  width: 130px !important;
  min-width: 130px !important;
  max-width: 130px !important;
  min-height: 48px !important;
  height: 48px !important;
}

/* 否/是 这种二选一不要撑满一整行 */
.qy-cart-configure-page .btn-group-toggle > label.btn:only-child {
  flex: 0 0 118px !important;
  width: 118px !important;
}

/* 防止图标和文字挤爆按钮 */
.qy-cart-configure-page label.btn img {
  width: 20px !important;
  height: 20px !important;
  object-fit: contain !important;
  flex: 0 0 20px !important;
}

/* selectpicker 和普通 select 尺寸统一 */
.qy-cart-configure-page .bootstrap-select,
.qy-cart-configure-page select.form-control,
.qy-cart-configure-page .selectpicker {
  width: 220px !important;
  max-width: 220px !important;
}

.qy-cart-configure-page .bootstrap-select > .dropdown-toggle,
.qy-cart-configure-page .selectpicker + .dropdown-toggle {
  width: 220px !important;
  min-height: 46px !important;
  height: 46px !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 36px 0 14px !important;
  overflow: hidden !important;
}

.qy-cart-configure-page .bootstrap-select .filter-option {
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
}

.qy-cart-configure-page .bootstrap-select .filter-option-inner,
.qy-cart-configure-page .bootstrap-select .filter-option-inner-inner {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* 下拉菜单不遮挡成一大片，宽度跟按钮一致 */
.qy-cart-configure-page .bootstrap-select .dropdown-menu {
  width: 220px !important;
  min-width: 220px !important;
  max-width: 260px !important;
  border-radius: 16px !important;
}

.qy-cart-configure-page .bootstrap-select .dropdown-menu.inner {
  max-height: 260px !important;
  overflow-y: auto !important;
}

.qy-cart-configure-page .bootstrap-select .dropdown-item {
  min-height: 38px !important;
  padding: 8px 12px !important;
  font-size: 13px !important;
}

.qy-cart-configure-page .bootstrap-select .dropdown-item img {
  width: 20px !important;
  height: 20px !important;
  object-fit: contain !important;
}

/* 滑块行恢复正常，不被固定按钮宽度影响 */
.qy-cart-configure-page .configoption_range {
  flex: 1 1 auto !important;
  min-width: 260px !important;
  max-width: none !important;
  width: auto !important;
}

.qy-cart-configure-page .configoption_range_val {
  flex: 0 0 86px !important;
  width: 86px !important;
  max-width: 86px !important;
  min-width: 86px !important;
  margin-left: 14px !important;
}

/* 主机名/密码输入框宽度统一 */
.qy-cart-configure-page input[name="host"],
.qy-cart-configure-page #password,
.qy-cart-configure-page .getPassword {
  width: 220px !important;
  max-width: 220px !important;
}

/* 覆盖上一版移动端把按钮强制 50% 的规则，桌面绝对不拉伸 */
@media (min-width: 769px) {
  .qy-cart-configure-page .btn-group-toggle > .btn,
  .qy-cart-configure-page .btn-group-toggle label.btn,
  .qy-cart-configure-page .btn-custom,
  .qy-cart-configure-page label.btn.btn-primary,
  .qy-cart-configure-page label.btn.btn-sm,
  .qy-cart-configure-page .cycle label.btn {
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
  }
}

@media (max-width: 768px) {
  .qy-cart-configure-page .configureproduct,
  .qy-cart-configure-page .form-group.row {
    display: block !important;
  }

  .qy-cart-configure-page .configureproduct > label.col-form-label,
  .qy-cart-configure-page .form-group.row > label.col-form-label {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 10px !important;
  }

  .qy-cart-configure-page .configureproduct > .col-md-10,
  .qy-cart-configure-page .form-group.row > .col-md-10,
  .qy-cart-configure-page .configureproduct > .col-md-3,
  .qy-cart-configure-page .form-group.row > .col-md-3,
  .qy-cart-configure-page .configureproduct > .col-md-2,
  .qy-cart-configure-page .form-group.row > .col-md-2,
  .qy-cart-configure-page .configureproduct > .col-8,
  .qy-cart-configure-page .form-group.row > .col-8 {
    width: 100% !important;
    max-width: 100% !important;
  }

  .qy-cart-configure-page .btn-group-toggle > label.btn,
  .qy-cart-configure-page .btn-group-toggle > .btn,
  .qy-cart-configure-page label.btn.btn-primary,
  .qy-cart-configure-page label.btn.btn-sm,
  .qy-cart-configure-page .btn-custom,
  .qy-cart-configure-page .cycle > label.btn,
  .qy-cart-configure-page .cycle .btn-custom {
    flex: 0 0 calc(50% - 5px) !important;
    width: calc(50% - 5px) !important;
    max-width: calc(50% - 5px) !important;
  }

  .qy-cart-configure-page .bootstrap-select,
  .qy-cart-configure-page select.form-control,
  .qy-cart-configure-page .selectpicker,
  .qy-cart-configure-page .bootstrap-select > .dropdown-toggle,
  .qy-cart-configure-page .selectpicker + .dropdown-toggle,
  .qy-cart-configure-page input[name="host"],
  .qy-cart-configure-page #password,
  .qy-cart-configure-page .getPassword {
    width: 100% !important;
    max-width: 100% !important;
  }
}

@media (max-width: 420px) {
  .qy-cart-configure-page .btn-group-toggle > label.btn,
  .qy-cart-configure-page .btn-group-toggle > .btn,
  .qy-cart-configure-page label.btn.btn-primary,
  .qy-cart-configure-page label.btn.btn-sm,
  .qy-cart-configure-page .btn-custom,
  .qy-cart-configure-page .cycle > label.btn,
  .qy-cart-configure-page .cycle .btn-custom {
    flex-basis: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
  }
}


/* =========================================================
   qy-cart configure v6：区域/机型自适应 + 镜像不换行 + 不影响导航/页脚
   ========================================================= */

/* 确保购物车配置页样式只作用在配置页容器里的表单，不碰 web header 与 footer */
.qy-cart-web-header .dropdown-menu,
.qy-cart-web-header .dropdown-item,
.qy-cart-web-header .btn,
.qy-cart-web-header .form-control {
  all: revert-layer;
}

/* 区域、数据中心、机型、镜像这些长文本项自动宽度 */
.qy-cart-configure-page #addCartForm .qy-cart-adaptive-option .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .qy-cart-adaptive-option .btn-group-toggle > .btn,
.qy-cart-configure-page #addCartForm .qy-cart-adaptive-option label.btn.btn-primary,
.qy-cart-configure-page #addCartForm .qy-cart-adaptive-option label.btn.btn-sm,
.qy-cart-configure-page #addCartForm .qy-cart-adaptive-option .btn-custom {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 148px !important;
  max-width: 100% !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
}

/* 区域/机型类可以更宽，避免文字挤 */
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > .btn,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-primary,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-sm,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-custom {
  min-width: 176px !important;
}

/* 镜像/系统下拉：图标和文字必须一行显示 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select,
.qy-cart-configure-page #addCartForm .qy-cart-os-option select.form-control,
.qy-cart-configure-page #addCartForm .qy-cart-os-option .selectpicker,
.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select > .dropdown-toggle,
.qy-cart-configure-page #addCartForm .qy-cart-os-option .selectpicker + .dropdown-toggle {
  width: auto !important;
  min-width: 220px !important;
  max-width: 360px !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select .filter-option,
.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select .filter-option-inner,
.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select .filter-option-inner-inner,
.qy-cart-configure-page #addCartForm .bootstrap-select .filter-option-inner-inner {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
}

.qy-cart-configure-page #addCartForm .bootstrap-select .filter-option-inner-inner img,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item img,
.qy-cart-configure-page #addCartForm label.btn img {
  display: inline-block !important;
  flex: 0 0 20px !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  object-fit: contain !important;
  margin-right: 7px !important;
  vertical-align: middle !important;
}

/* 下拉选项内部也不换行 */
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item span,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item .text {
  white-space: nowrap !important;
  word-break: keep-all !important;
}

/* 区域/机型下拉自适应宽度 */
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .bootstrap-select,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option select.form-control,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .selectpicker,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .bootstrap-select > .dropdown-toggle,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .selectpicker + .dropdown-toggle {
  width: auto !important;
  min-width: 220px !important;
  max-width: 520px !important;
}

/* 修复操作系统两列下拉间距 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2,
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 + .col-md-3 {
  margin-left: 12px !important;
}

/* 2核、2G、30G 这类普通数字配置继续统一尺寸，不被 adaptive 影响 */
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > .btn,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-primary,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-sm,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-custom {
  flex: 0 0 118px !important;
  width: 118px !important;
  min-width: 118px !important;
  max-width: 118px !important;
}

/* 不再全局隐藏 footer，避免影响页脚 */
body.qy-cart-mode .footer {
  display: block;
}

@media (max-width: 768px) {
  .qy-cart-configure-page #addCartForm .qy-cart-adaptive-option .btn-group-toggle > label.btn,
  .qy-cart-configure-page #addCartForm .qy-cart-adaptive-option .btn-group-toggle > .btn,
  .qy-cart-configure-page #addCartForm .qy-cart-adaptive-option label.btn.btn-primary,
  .qy-cart-configure-page #addCartForm .qy-cart-adaptive-option label.btn.btn-sm,
  .qy-cart-configure-page #addCartForm .qy-cart-adaptive-option .btn-custom,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > label.btn,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > .btn,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-primary,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-sm,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-custom {
    flex: 1 1 100% !important;
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option select.form-control,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option .selectpicker,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select > .dropdown-toggle,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option .selectpicker + .dropdown-toggle,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .bootstrap-select,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option select.form-control,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .selectpicker,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .bootstrap-select > .dropdown-toggle,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .selectpicker + .dropdown-toggle {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 + .col-md-3 {
    margin-left: 0 !important;
    margin-top: 10px !important;
  }
}


/* =========================================================
   qy-cart configure v7：选配模块对齐 + 网络类型长按钮
   ========================================================= */

/* 配置项统一采用：左标题固定、右内容统一起点 */
.qy-cart-configure-page #addCartForm .configureproduct,
.qy-cart-configure-page #addCartForm .form-group.row {
  display: grid !important;
  grid-template-columns: 126px minmax(0, 1fr) !important;
  column-gap: 18px !important;
  row-gap: 10px !important;
  align-items: center !important;
  padding: 22px 0 !important;
}

/* 左侧标题统一宽度，防止“网络类型”等把内容挤偏 */
.qy-cart-configure-page #addCartForm .configureproduct > label.col-form-label,
.qy-cart-configure-page #addCartForm .form-group.row > label.col-form-label {
  grid-column: 1 !important;
  width: 126px !important;
  max-width: 126px !important;
  min-width: 126px !important;
  flex: none !important;
  padding: 0 !important;
  margin: 0 !important;
  word-break: keep-all !important;
}

/* 右侧所有内容统一从第二列开始 */
.qy-cart-configure-page #addCartForm .configureproduct > .col-md-10,
.qy-cart-configure-page #addCartForm .form-group.row > .col-md-10,
.qy-cart-configure-page #addCartForm .configureproduct > .col-md-3,
.qy-cart-configure-page #addCartForm .form-group.row > .col-md-3,
.qy-cart-configure-page #addCartForm .configureproduct > .col-md-2,
.qy-cart-configure-page #addCartForm .form-group.row > .col-md-2,
.qy-cart-configure-page #addCartForm .configureproduct > .col-8,
.qy-cart-configure-page #addCartForm .form-group.row > .col-8,
.qy-cart-configure-page #addCartForm .configureproduct > .d-inline-flex,
.qy-cart-configure-page #addCartForm .form-group.row > .d-inline-flex,
.qy-cart-configure-page #addCartForm .configureproduct > .col-1,
.qy-cart-configure-page #addCartForm .form-group.row > .col-1 {
  grid-column: 2 !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  flex: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* 密码显示按钮和随机按钮跟密码输入框在同一行 */
.qy-cart-configure-page #addCartForm .form-group.row > .d-inline-flex,
.qy-cart-configure-page #addCartForm .form-group.row > .col-1 {
  display: inline-flex !important;
  width: auto !important;
  margin-left: 12px !important;
}

/* 右侧按钮区域固定从同一条线开始 */
.qy-cart-configure-page #addCartForm .btn-group-toggle,
.qy-cart-configure-page #addCartForm .btn-custom-group,
.qy-cart-configure-page #addCartForm .cycle,
.qy-cart-configure-page #addCartForm .justify-content-start {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 10px !important;
  width: 100% !important;
  padding-top: 0 !important;
}

/* 普通配置按钮：2核、2G、30G 等统一尺寸 */
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > .btn,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-primary,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-sm,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-custom {
  flex: 0 0 104px !important;
  width: 104px !important;
  min-width: 104px !important;
  max-width: 104px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 0 10px !important;
}

/* 宽配置按钮：机型、区域、网络类型更长，自适应但有最低宽度 */
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > .btn,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-primary,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-sm,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-custom {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 230px !important;
  max-width: 100% !important;
  height: 44px !important;
  min-height: 44px !important;
  padding: 0 18px !important;
}

/* 网络类型一般文字最长，再给宽一点 */
.qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn {
  white-space: nowrap !important;
}

/* 是/否这类普通项继续保持小按钮，不要被拉长 */
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-wide-option) .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-wide-option) .btn-group-toggle > .btn {
  flex-grow: 0 !important;
}

/* 周期按钮统一但不占满 */
.qy-cart-configure-page #addCartForm .cycle > label.btn,
.qy-cart-configure-page #addCartForm .cycle .btn-custom {
  flex: 0 0 116px !important;
  width: 116px !important;
  min-width: 116px !important;
  max-width: 116px !important;
}

/* 镜像/系统两个下拉框同一行，图标和名称不换行 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option {
  align-items: center !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2,
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 {
  grid-column: 2 !important;
  display: inline-block !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 + .col-md-3 {
  margin-left: 14px !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select {
  width: 182px !important;
  min-width: 182px !important;
  max-width: 220px !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 .bootstrap-select {
  width: 220px !important;
  min-width: 220px !important;
  max-width: 260px !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select > .dropdown-toggle {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
}

/* 镜像当前值：图标 + CentOS 必须同行 */
.qy-cart-configure-page #addCartForm .bootstrap-select .filter-option,
.qy-cart-configure-page #addCartForm .bootstrap-select .filter-option-inner,
.qy-cart-configure-page #addCartForm .bootstrap-select .filter-option-inner-inner {
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  gap: 7px !important;
  min-width: 0 !important;
  width: 100% !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  text-overflow: ellipsis !important;
}

.qy-cart-configure-page #addCartForm .bootstrap-select .filter-option-inner-inner img,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item img {
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  flex: 0 0 20px !important;
  object-fit: contain !important;
  margin-right: 6px !important;
  vertical-align: middle !important;
}

.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-menu {
  min-width: 220px !important;
  width: max-content !important;
  max-width: 320px !important;
}

.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item span,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item .text {
  white-space: nowrap !important;
  word-break: keep-all !important;
}

/* 独享带宽滑块对齐 */
.qy-cart-configure-page #addCartForm .configoption_range {
  width: auto !important;
  min-width: 320px !important;
  flex: 1 1 auto !important;
}

.qy-cart-configure-page #addCartForm .configoption_range_val {
  flex: 0 0 86px !important;
  width: 86px !important;
  min-width: 86px !important;
  max-width: 86px !important;
}

/* 主机名/密码输入框和上面选框起点一致 */
.qy-cart-configure-page #addCartForm input[name="host"],
.qy-cart-configure-page #addCartForm #password,
.qy-cart-configure-page #addCartForm .getPassword {
  width: 220px !important;
  min-width: 220px !important;
  max-width: 220px !important;
}

/* 页面右侧汇总不压到左侧内容 */
.qy-cart-configure-page > form > .row {
  column-gap: 24px !important;
}

.qy-cart-configure-page .col-xl-8 {
  flex: 0 0 calc(100% - 380px) !important;
  max-width: calc(100% - 380px) !important;
}

.qy-cart-configure-page .col-xl-4 {
  flex: 0 0 356px !important;
  max-width: 356px !important;
}

/* 不影响导航栏和页脚：只隐藏用户中心那套，不动 qy-cart-web-header 和 footer */
body.qy-cart-mode .qy-cart-web-header .qy-header {
  display: block !important;
}

body.qy-cart-mode .footer {
  display: block !important;
}

@media (max-width: 1199px) {
  .qy-cart-configure-page .col-xl-8,
  .qy-cart-configure-page .col-xl-4 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}

@media (max-width: 768px) {
  .qy-cart-configure-page #addCartForm .configureproduct,
  .qy-cart-configure-page #addCartForm .form-group.row {
    display: block !important;
  }

  .qy-cart-configure-page #addCartForm .configureproduct > label.col-form-label,
  .qy-cart-configure-page #addCartForm .form-group.row > label.col-form-label {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 10px !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > label.btn,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-group-toggle > .btn,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-primary,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option label.btn.btn-sm,
  .qy-cart-configure-page #addCartForm .qy-cart-wide-option .btn-custom,
  .qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > label.btn,
  .qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > .btn,
  .qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-primary,
  .qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-sm,
  .qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-custom,
  .qy-cart-configure-page #addCartForm .cycle > label.btn,
  .qy-cart-configure-page #addCartForm .cycle .btn-custom {
    flex: 0 0 calc(50% - 5px) !important;
    width: calc(50% - 5px) !important;
    min-width: calc(50% - 5px) !important;
    max-width: calc(50% - 5px) !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 {
    display: block !important;
    width: 100% !important;
    margin-left: 0 !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 + .col-md-3 {
    margin-top: 10px !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 .bootstrap-select,
  .qy-cart-configure-page #addCartForm input[name="host"],
  .qy-cart-configure-page #addCartForm #password,
  .qy-cart-configure-page #addCartForm .getPassword {
    width: 100% !important;
    max-width: 100% !important;
  }
}


/* =========================================================
   qy-cart configure v8：修复镜像双下拉同一行与下拉层错位
   ========================================================= */

/* 所有配置行改回弹性布局：左标题固定，右侧控件自然横向排列 */
.qy-cart-configure-page #addCartForm .configureproduct,
.qy-cart-configure-page #addCartForm .form-group.row {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 18px !important;
  padding: 22px 0 !important;
}

.qy-cart-configure-page #addCartForm .configureproduct > label.col-form-label,
.qy-cart-configure-page #addCartForm .form-group.row > label.col-form-label {
  flex: 0 0 126px !important;
  width: 126px !important;
  max-width: 126px !important;
  min-width: 126px !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* 右侧通用内容区 */
.qy-cart-configure-page #addCartForm .configureproduct > .col-md-10,
.qy-cart-configure-page #addCartForm .form-group.row > .col-md-10 {
  flex: 1 1 auto !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* 普通输入/下拉的基础宽度 */
.qy-cart-configure-page #addCartForm .configureproduct > .col-md-3,
.qy-cart-configure-page #addCartForm .form-group.row > .col-md-3,
.qy-cart-configure-page #addCartForm .configureproduct > .col-md-2,
.qy-cart-configure-page #addCartForm .form-group.row > .col-md-2,
.qy-cart-configure-page #addCartForm .configureproduct > .col-8,
.qy-cart-configure-page #addCartForm .form-group.row > .col-8 {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* 镜像/操作系统：两个选择框必须在同一行 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > label.col-form-label {
  flex: 0 0 126px !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2,
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 {
  display: block !important;
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 + .col-md-3 {
  margin-left: 14px !important;
}

/* 第一个镜像分类框，如 CentOS/Debian */
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 .bootstrap-select,
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 select.form-control {
  width: 176px !important;
  min-width: 176px !important;
  max-width: 176px !important;
}

/* 第二个镜像版本框，如 CentOS_7.4_x64 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 .bootstrap-select,
.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 select.form-control {
  width: 230px !important;
  min-width: 230px !important;
  max-width: 230px !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select > .dropdown-toggle {
  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 34px 0 14px !important;
  overflow: hidden !important;
}

/* 图标与文字同一行 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option .filter-option,
.qy-cart-configure-page #addCartForm .qy-cart-os-option .filter-option-inner,
.qy-cart-configure-page #addCartForm .qy-cart-os-option .filter-option-inner-inner,
.qy-cart-configure-page #addCartForm .bootstrap-select .filter-option-inner-inner {
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  min-width: 0 !important;
  width: 100% !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  text-overflow: ellipsis !important;
  line-height: 1 !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option .filter-option-inner-inner img,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item img {
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  object-fit: contain !important;
  margin: 0 7px 0 0 !important;
  vertical-align: middle !important;
}

/* 下拉菜单只比按钮略宽，不再盖出一大片 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option .bootstrap-select .dropdown-menu {
  width: 100% !important;
  min-width: 176px !important;
  max-width: 260px !important;
  border-radius: 16px !important;
  z-index: 1060 !important;
}

.qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 .bootstrap-select .dropdown-menu {
  min-width: 230px !important;
  max-width: 280px !important;
}

.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-menu.inner {
  max-height: 220px !important;
  overflow-y: auto !important;
}

.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item span,
.qy-cart-configure-page #addCartForm .bootstrap-select .dropdown-item .text {
  display: flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  line-height: 1.4 !important;
}

/* 修复之前 grid 布局留下的同列覆盖问题 */
.qy-cart-configure-page #addCartForm .qy-cart-os-option > * {
  grid-column: auto !important;
}

/* 普通配置按钮仍保持对齐 */
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-group-toggle > .btn,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-primary,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) label.btn.btn-sm,
.qy-cart-configure-page #addCartForm .configureproduct:not(.qy-cart-adaptive-option) .btn-custom {
  flex: 0 0 104px !important;
  width: 104px !important;
  min-width: 104px !important;
  max-width: 104px !important;
}

/* 网络类型等长按钮保持长一些 */
.qy-cart-configure-page #addCartForm .qy-cart-wide-option:not(.qy-cart-os-option) .btn-group-toggle > label.btn,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option:not(.qy-cart-os-option) .btn-group-toggle > .btn,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option:not(.qy-cart-os-option) label.btn.btn-primary,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option:not(.qy-cart-os-option) label.btn.btn-sm,
.qy-cart-configure-page #addCartForm .qy-cart-wide-option:not(.qy-cart-os-option) .btn-custom {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 230px !important;
  max-width: 100% !important;
}

/* 移动端镜像两框上下排列 */
@media (max-width: 768px) {
  .qy-cart-configure-page #addCartForm .configureproduct,
  .qy-cart-configure-page #addCartForm .form-group.row,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option {
    display: block !important;
  }

  .qy-cart-configure-page #addCartForm .configureproduct > label.col-form-label,
  .qy-cart-configure-page #addCartForm .form-group.row > label.col-form-label {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 10px !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 {
    width: 100% !important;
    max-width: 100% !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 + .col-md-3 {
    margin-left: 0 !important;
    margin-top: 10px !important;
  }

  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 .bootstrap-select,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 .bootstrap-select,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-2 select.form-control,
  .qy-cart-configure-page #addCartForm .qy-cart-os-option > .col-md-3 select.form-control {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
  }
}
