/* Base user layout --------------------- */
.section-user {
  padding-top: 2rem;
  padding-bottom: 2rem;
  --lg-user-panel-width: 300px;
}

.section-user .col-user-content-full {
  padding-top: 45px;
  padding-bottom: 45px;
  max-width: 600px;
  float: none;
  margin-left: auto;
  margin-right: auto;
}

.title-user-section {
  display: block;
  max-width: 100%;
  margin-bottom: 1.5rem;
  font-family: var(--ff-bold);
  font-size: 1.5rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.col-user-menu .user-panel-container {
  margin: 1.5rem 0;
}

.col-user-menu .user-panel-container .dropdown-menu {
  margin-top: -1px;
  border-left-width: 0;
  border-right-width: 0;
  width: 100%;
}

.col-user-menu .user-panel-container .btn.btn-user-panel {
  width: 100%;
  text-transform: none;
  justify-content: space-between;
  margin-top: -1rem;
}

.col-user-menu .user-panel-container .btn.btn-user-panel .text {
  margin-right: auto;
  margin-left: 1rem;
}

.col-user-menu .user-panel-container .btn.btn-user-panel .icon-menu {
  height: 16px;
  width: 16px;
}

.col-user-menu .user-panel-container .btn.btn-user-panel .icon-angle {
  width: 12px;
  height: 12px;
  transform: rotate(180deg);
  transition: transform 375ms ease;
}

.col-user-menu .user-panel-container .btn.btn-user-panel.collapsed .icon-angle {
  transform: rotate(0deg);
}

.col-user-menu .user-panel-container .userControlPanel {
  margin-top: 1rem;
}

.section-user .userPanelRewardPoints {
  display: none;
}

@media (min-width: 768px) {
  .section-user {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .section-user .col-user-menu {
    width: var(--lg-user-panel-width);
    padding-right: 2rem;
  }

  .section-user .col-user-content {
    width: calc(100% - var(--lg-user-panel-width));
  }

  .col-user-menu .user-panel-container {
    margin-left: 0;
    margin-right: 0;
  }

  .col-user-menu .user-panel-container,
  .col-user-menu .user-panel-container .userControlPanel {
    margin-top: 0;
  }
}

@media (min-width: 1400px) {
  .section-user {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}

/* User logged -------------------------- */
.section-user-logged .userTitle {
  display: none;
}

.section-user-logged .basketButtons {
  padding: 0;
  float: none;
}

.section-user-logged #customerFormSubmit {
  width: 100%;
}

@media (min-width: 576px) {
  .section-user-logged #customerFormSubmit {
    max-width: var(--tipical-min-button-width);
  }
}

@media (min-width: 1200px) {
  .section-user-logged .col-user-content :where(.content, .title-user-section) {
    max-width: calc(100% - var(--lg-user-panel-width));
    margin-left: auto;
    margin-right: auto;
  }
}

/* User addressBook --------------------- */
.section-user-addressbook .blockAddressBook>.title {
  max-width: 100%;
  margin-bottom: 1.25rem;
  font-family: var(--ff-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 16px;
  position: relative;
  display: flex;
  align-items: center;
}

.section-user-addressbook .blockAddressBook>.title::before {
  content: "";
  height: 1rem;
  width: 1rem;
  margin-right: .75rem;
  display: block;
  background-repeat: no-repeat;
  background-position: center;
}

.section-user-addressbook .blockAddressBook.billing>.title::before {
  background-image: url('../../img/osc/address-card-billing.svg');
}

.section-user-addressbook .blockAddressBook.shipping>.title::before {
  background-image: url('../../img/osc/address-card-shipping.svg');
}

.section-user-addressbook #addressBookContainer {
  padding-top: 15px;
}

.section-user-addressbook .blockAddressBook .addressBook {
  margin-bottom: 1.25rem;
}

.section-user-addressbook .adressSetAsDefault {
  overflow: hidden;
  max-width: 100%;
  text-overflow: ellipsis;
  font-size: 13px;
  margin-top: 15px;
  color: var(--color-primary);
  height: auto;
  line-height: 1.4;
  border: 0;
  background-color: transparent;
  text-transform: none;
  padding: 8px;
  margin-left: -8px;
  margin-bottom: -8px;
}

.section-user-addressbook .adressSetAsDefault:hover,
.section-user-addressbook .adressSetAsDefault:active {
  background-color: transparent;
  color: var(--color-link-hover);
}

.section-user-addressbook .notAvailableAddress {
  display: block;
  padding: 15px 20px;
  border: 1px solid #ddd;
  border-radius: 3px;
}

.section-user-addressbook .addAddressBook.btn-link {
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
  position: relative;
  margin-bottom: 1.25rem;
  padding: 10px;
  border-radius: .5rem;
  color: var(--gray-900);
  background-color: var(--gray-100);
  border: 1px solid var(--gray-400);
  transition: background-color 150ms ease, border-color 150ms ease;
  font-size: 12px;
}

.section-user-addressbook .addAddressBook.btn .icon {
  width: 15px;
  height: 15px;
}

.section-user-addressbook .addAddressBook.btn-link:hover {
  background-color: var(--gray-200);
  border: 1px solid var(--gray-700);
}

.section-user-addressbook #shippingAddressContainer {
  margin-top: 1rem;
}

@media (min-width: 576px) {
  .section-user-addressbook .adressSetAsDefault {
    font-size: 14px;
  }
}

@media (min-width: 992px) {
  .section-user-addressbook #shippingAddressContainer {
    margin-top: 0;
  }
}

/* User add/edit addressBook ------------ */
:where(.section-user-add-addressbook, .section-user-edit-addressbook) :where(#billingAddressFormTitle, #shippingAddressFormTitle) {
  display: none;
}

:where(.section-user-add-addressbook, .section-user-edit-addressbook) #addressFormSubmit {
  width: 100%;
}

@media(min-width: 576px) {
  :where(.section-user-add-addressbook, .section-user-edit-addressbook) #addressFormSubmit {
    max-width: var(--tipical-min-button-width);
  }
}

/* Change password ---------------------- */
.section-user-change-password #changePasswordSubmitContainer {
  margin-bottom: 0;
}

.section-user-change-password :where(#changePasswordSubmit, #updatePasswordSubmit) {
  width: 100%;
}

@media (min-width: 576px) {
  .section-user-change-password :where(#changePasswordSubmit, #updatePasswordSubmit) {
    max-width: var(--tipical-min-button-width);
  }
}

@media (min-width: 1200px) {
  .section-user-change-password .col-user-content :where(.content, .title-user-section) {
    max-width: calc(100% - var(--lg-user-panel-width));
    margin-left: auto;
    margin-right: auto;
  }
}

/* Wishlist ----------------------------- */
.section-user-wishlist .empty-text {
  display: block;
  padding: .75rem 0;
}

.section-user-wishlist .wishlist-buttons {
  margin-bottom: 2rem;
}

.section-user-wishlist .wishlist-buttons .btn-wish-action {
  width: 100%;
}

.section-user-wishlist .col-user-menu .btn-wish-action {
  width: 100%;
  font-size: 13px;
  padding-left: .75rem;
  padding-right: .75rem;
  border-radius: 0;
}

.wishlist-page-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin: 2.5rem 0;
}

.section-user-wishlist .module {
  padding-top: 0;
  padding-bottom: 0;
}

.wishlist-pagination-container {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.wishlist-pagination-container .block-pagination {
  display: table;
  margin: 0 auto;
}

.lcContent-userWishlist .title-user-section {
  margin-bottom: 0.75rem;
}

.lcContent-userWishlist .module-products-grid-02 .grid-items {
  gap: 0.75rem;
}

@media (min-width:992px) and (max-width:1199px) {
  .lcContent-userWishlist .module-products-grid-02 .grid-items {
    grid-template-columns: repeat(3, 1fr);
  }
}

.lcContent-userWishlist .product-list .product-list-content {
  background-color: var(--gray-200);
}

.lcContent-userWishlist .product-list .product-list-content .button-container {
  display: none;
}

/* Stock alerts ------------------------- */
#unsubscribeStockAlertForm {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.stockAlertsRecord {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background-color: #fff;
  background-clip: border-box;
  border: 1px solid var(--light-border);
  border-radius: 0.5rem;
  margin-bottom: 0;
}

.stockAlertsHeader {
  padding: .75rem 3.5rem .75rem 1rem;
}

.stockAlertsProduct {
  padding: 1rem;
  display: flex;
  gap: .75rem;
}

.stockAlertsProductImage {
  max-width: 50px;
}

.stockAlertsHeader.stockAlertsHeader1 {
  border-bottom: 0;
  padding-bottom: 0;
}

.stockAlertsHeader.stockAlertsHeader2 {
  padding-top: 0.25rem;
  display: flex;
  justify-content: space-between;
  border-bottom-color: var(--light-border);
}

.stockAlertsDelete {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
}

.unsubscribeStockAlertButton {
  display: block;
  background-image: url(../../img/delete-basket.svg);
  height: 2rem;
  width: 2rem;
  background-size: 14px;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 1;
  border: 0;
  background-color: transparent;
  padding: 0;
}

.stockAlertsProductName {
  display: block;
  font-family: var(--ff-bold);
  margin-bottom: .5rem;
}

.stockAlertsProductOptions {
  color: var(--gray-600);
  margin-bottom: 0;
  font-size: 12px;
}

@media (max-width: 575px) {
  .stockAlerts {
    font-size: 0.9em;
  }
}

@media (min-width: 576px) {
  .stockAlertsProduct {
    align-items: center;
  }

  .stockAlertsProductImage {
    max-width: 75px;
  }
}

/* User orders -------------------------- */
.userOrders.userOrdersWithOrders,
.userOrderShipmentsContainer {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.userOrder,
.userOrderShipment {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background-color: #fff;
  background-clip: border-box;
  border: 1px solid var(--light-border);
  border-radius: 0.5rem;
  margin-bottom: 0;
}

.userOrderAction {
  height: auto;
  letter-spacing: inherit;
  font-size: inherit;
}

.userOrderAction.btn {
  padding: .375rem .75rem;
}

.userOrderShipmentsHeader {
  padding: .75rem 1rem;
  border-top-color: var(--light-border);
  border-bottom-color: var(--light-border);
  flex-wrap: wrap;
}

.userOrderAction img {
  -webkit-filter: saturate(0) brightness(1.5);
  filter: saturate(0) brightness(1.5);
  position: static;
  transform: none;
  margin-right: .5rem;
  width: 1rem;
  height: 1rem;
}

.userOrderHeader {
  padding: .75rem 1rem;
}

.userOrderHeader .lbl,
.stockAlertsHeader .lbl,
.userOrderShipmentsHeader {
  color: var(--gray-500);
}

.userOrderHeader .lbl::after,
.stockAlertsHeader .lbl::after,
.userOrderShipmentsHeader::after {
  content: ":";
}

.userOrderActions,
.userOrderShipmentsData {
  padding: 0.75rem .25rem;
}

.userOrderStatus {
  width: auto;
  float: none;
}

.userOrderNum {
  width: auto;
  float: none;
  padding-right: 1rem;
}

.userOrderNum .val {
  color: var(--color-dark);
  font-family: var(--ff-bold);
}

.userOrderActions>div,
.userOrderShipmentsData>div {
  float: none;
  margin: 0;
  padding: 0;
}

.userOrderActions::before,
.userOrderActions::after,
.userOrderHeader::before,
.userOrderHeader::after,
.userOrderShipmentHeader::before,
.userOrderShipmentHeader::after {
  display: none;
}

.userOrderHeader.userOrderHeader1,
.userOrderShipmentHeader.userOrderShipmentHeader1 {
  border-bottom: 0;
  padding-bottom: 0;
}

.userOrderHeader.userOrderHeader2,
.userOrderShipmentHeader.userOrderShipmentHeader2 {
  padding-top: 0.25rem;
  display: flex;
  justify-content: space-between;
  border-bottom-color: var(--light-border);
}

.userOrders :where(.userOrderActions, .userOrderShipmentsData) {
  display: grid;
  align-items: center;
  gap: .75rem;
}

.userOrderAction.btn {
  font-size: 12px;
  width: 100%;
  justify-content: inherit;
  font-family: var(--ff-bold);
  letter-spacing: 0.06em;
}

.userOrderAction.btn:hover {
  text-decoration: underline;
}

.userOrderAction.btn:hover img {
  opacity: 0.7;
}

span.userOrderAction.btn {
  cursor: inherit;
  -webkit-user-select: auto;
  -ms-user-select: auto;
  user-select: auto;
}

.userOrderShipmentsNum {
  width: 100%;
  margin-top: .25rem;
}

.userOrderShipmentNumber b {
  color: var(--color-dark);
}

.userOrderShipmentBody .userOrderActionWrap {
  padding: 0;
}

.userOrderShipmentBody .orderProductName~* {
  font-size: 12px;
  color: var(--gray-600);
}

@media (min-width: 992px) {
  .userOrderShipmentBody .userOrderAction.shipmentTracking {
    margin-left: 2rem;
  }
}

@media (min-width: 992px),
(min-width: 576px) and (max-width: 767px) {
  .userOrders :where(.userOrderActions, .userOrderShipmentsData) {
    grid-template-columns: repeat(2, 1fr);
  }

  .userOrderShipmentsNum {
    width: auto;
    margin-top: 0;
  }
}

@media (min-width: 1200px) {
  .userOrders :where(.userOrderActions, .userOrderShipmentsData) {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1400px) {
  .userOrders :where(.userOrderActions, .userOrderShipmentsData) {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Delete account ----------------------- */
.section-user-delete-account .text-delete-account {
  margin-bottom: 20px;
  color: #999;
}

.section-user-delete-account #deleteAccountSubmitContainer .btn {
  width: 100%;
}

@media (min-width: 576px) {
  .section-user-delete-account #deleteAccountSubmitContainer .btn {
    max-width: var(--tipical-min-button-width);
  }
}

@media (min-width: 1200px) {
  .section-user-delete-account .col-user-content :where(.content, .title-user-section) {
    max-width: calc(100% - var(--lg-user-panel-width));
    margin-left: auto;
    margin-right: auto;
  }
}

/* Lost password ------------------------ */
.section-user-lost-pass #lostPasswordSubmit {
  width: 100%;
}

@media (min-width: 576px) {
  .section-user-lost-pass #lostPasswordSubmit {
    max-width: var(--tipical-min-button-width);
  }
}

/* PaymentCards ------------------------- */
.paymentCardsContainer {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.payment-plugin-header {
  display: block;
  max-width: 100%;
  margin-bottom: 1rem;
  font-family: var(--ff-bold);
  font-size: 1.25rem;
  color: var(--gray-700);
}

.paymentCards {
  display: grid;
  gap: 1.5rem;
}

.paymentCard {
  min-width: 0;
}

.paymentCard .wrap {
  border: 1px solid var(--light-border);
  border-radius: .5rem;
  overflow: auto;
  padding: 1.25rem 1.5rem;
}

.paymentCard .actionButtons {
  margin-top: .75rem;
}

.paymentCard .actionButtons .btn {
  min-width: var(--tipical-min-button-width);
}

.userPaymentCardData {
  font-size: 12px;
}

.userPaymentCardData .field .label {
  font-family: var(--ff-bold);
}

.userPaymentCardData .field .value {
  color: var(--gray-700);
}

@media(min-width: 576px) and (max-width: 767px),
(min-width: 992px) {
  .paymentCards {
    grid-template-columns: 1fr 1fr;
  }
}

@media(min-width: 1400px) {
  .paymentCards {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

/* CompleteAccount ---------------------- */
.section-user-complete-account .confirmAccountButton {
  width: 100%;
  margin-top: 15px;
}

@media (min-width: 576px) {
  .section-user-complete-account .confirmAccountButton {
    width: var(--tipical-min-button-width);
  }
}