/* ============================================
   CUSTOMER ACCOUNT PAGES
   ============================================ */

:root {
  --nf-account-surface: #ffffff;
  --nf-account-surface-soft: #f8fafc;
  --nf-account-line: #e2e8f0;
  --nf-account-line-soft: #edf2f7;
  --nf-account-line-dashed: #e2e8f0;
  --nf-account-text: #1d2433;
  --nf-account-text-soft: #334155;
  --nf-account-text-muted: #475569;
  --nf-account-text-faint: #64748b;
  --nf-account-text-ghost: #94a3b8;
  --nf-account-accent: #f51359;
  --nf-account-accent-soft: rgba(245, 19, 89, 0.06);
  --nf-account-accent-soft-hover: rgba(245, 19, 89, 0.08);
  --nf-account-accent-soft-active: rgba(245, 19, 89, 0.12);
  --nf-account-accent-ring: rgba(245, 19, 89, 0.16);
  --nf-account-accent-border: rgba(245, 19, 89, 0.2);
  --nf-account-accent-border-strong: rgba(245, 19, 89, 0.24);
  --nf-account-info-surface: #ecfeff;
  --nf-account-info-border: #a5f3fc;
  --nf-account-info-text: #155e75;
  --nf-account-info-surface-alt: #eff6ff;
  --nf-account-info-border-alt: #bfdbfe;
  --nf-account-info-text-alt: #1e3a8a;
  --nf-account-danger-surface: #fef2f2;
  --nf-account-danger-border: #fecaca;
  --nf-account-danger-text: #b91c1c;
  --nf-account-success-surface: #f0fdf4;
  --nf-account-success-border: #bbf7d0;
  --nf-account-success-text: #15803d;
  --nf-account-overlay-surface: rgba(255, 255, 255, 0.95);
  --nf-account-overlay-surface-soft: rgba(248, 250, 252, 0.75);
  --nf-account-wallet-success: #16a34a;
  --nf-account-track-dark: #111827;
  --nf-account-shadow-sm: 0 2px 8px rgba(2, 6, 23, 0.04);
  --nf-account-shadow-md: 0 8px 24px rgba(2, 6, 23, 0.12);
  --nf-account-shadow-lg: 0 10px 30px rgba(2, 6, 23, 0.22);
  --nf-account-shadow-success: 0 2px 8px rgba(22, 163, 74, 0.18);
}

#vue-my-address .address-hero-box,
#location-addresses .address-hero-box {
  border: 1px solid var(--nf-account-line);
  border-radius: 12px;
  background: linear-gradient(180deg, var(--nf-account-surface) 0%, var(--nf-account-surface-soft) 100%);
  padding: 8px 10px !important;
}

#vue-my-address .address-hero-inline,
#location-addresses .address-hero-inline {
  gap: 10px;
}

#vue-my-address .address-hero-title-wrap h6,
#location-addresses .address-hero-title-wrap h6 {
  font-size: 15px;
  line-height: 1.15;
}

#vue-my-address .address-hero-title-wrap p,
#location-addresses .address-hero-title-wrap p {
  font-size: 12px;
  line-height: 1.2;
}

#vue-my-address .address-hero-count .address-count,
#location-addresses .address-hero-count .address-count {
  font-size: 24px;
  line-height: 1.1;
  margin-bottom: 2px;
}

#vue-my-address .address-add-btn,
#location-addresses .address-add-btn {
  min-width: 132px;
  min-height: 34px;
  border-radius: 9px;
  font-size: 12px;
  padding: 7px 10px;
}

#vue-my-address .address-add-btn--sm,
#location-addresses .address-add-btn--sm {
  min-width: 124px;
}

#vue-my-address .address-add-btn--xs,
#location-addresses .address-add-btn--xs {
  min-width: 80px;
  min-height: 32px;
}

#vue-my-address .address-count-badge,
#location-addresses .address-count-badge,
#vue-my-payments .payment-count-badge,
#vue-saved-store .saved-store-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 28px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--nf-account-info-surface);
  border: 1px solid var(--nf-account-info-border);
  color: var(--nf-account-info-text);
  font-size: 12px;
  font-weight: 700;
}

#vue-my-address .address-slot.card.address-item-card,
#location-addresses .address-slot.card.address-item-card,
#vue-my-payments .card-listing.payment-item-card,
#vue-saved-store .saved-store-card,
#vue-my-order .order-item-row {
  height: auto !important;
  border: 1px solid var(--nf-account-line);
  border-radius: 10px;
  box-shadow: var(--nf-account-shadow-sm);
}

#vue-my-address .address-slot.card.address-item-card,
#location-addresses .address-slot.card.address-item-card,
#vue-my-payments .card-listing.payment-item-card {
  min-height: 132px;
  display: flex;
  flex-direction: column;
}

#vue-my-address .address-item-card h5,
#location-addresses .address-item-card h5,
#vue-my-payments .payment-item-title {
  font-size: 15px;
  line-height: 1.2;
}

#vue-my-address .address-item-card .module p,
#location-addresses .address-item-card .module p,
#vue-my-payments .payment-item-subtext p,
#vue-my-order .order-items-line,
#vue-my-order .order-panel-overview p,
#vue-my-order .order-panel-customer p,
#vue-my-order .order-panel-booking p {
  color: var(--nf-account-text-muted);
  font-size: 13px;
  line-height: 1.35;
}

#vue-my-address .address-card-actions,
#location-addresses .address-card-actions,
#vue-my-payments .payment-card-actions {
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px dashed var(--nf-account-line-dashed);
}

#vue-my-address .address-card-actions .btn.small,
#location-addresses .address-card-actions .btn.small,
#vue-my-payments .payment-card-actions .btn.small {
  padding-left: 0;
  padding-right: 0;
  font-size: 12px;
  line-height: 1.2;
}

.account-page-title {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 38px;
  padding: 6px 12px;
  border: 1px solid var(--nf-account-accent-border);
  border-radius: 11px;
  background: var(--nf-account-accent-soft);
  color: var(--nf-account-text);
  font-size: 14px;
  font-weight: 700;
}

.account-page-title__icon {
  width: 28px;
  height: 28px;
  min-width: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9px;
  border: 1px solid var(--nf-account-accent-border-strong);
  background: var(--nf-account-accent-soft-active);
  color: var(--nf-account-accent);
  font-size: 16px;
}

.account-page-title__icon i {
  width: 1em;
  height: 1em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.account-page-title__icon i::before {
  display: block;
  line-height: 1;
}

body.column2-layout #sidebar .siderbar-menu {
  margin: 0;
  padding: 0;
}

body.column2-layout #sidebar .siderbar-menu li {
  margin-bottom: 5px;
}

body.column2-layout #sidebar .siderbar-menu li:last-child {
  margin-bottom: 0;
}

body.column2-layout #sidebar .siderbar-menu li > a {
  border-radius: 12px;
  transition: all 0.2s ease;
  color: var(--nf-ink-soft);
  padding: 9px 14px;
  text-indent: 0;
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: 10px;
  background-image: none !important;
}

body.column2-layout #sidebar .siderbar-menu li > a .menu-icon {
  width: 18px;
  min-width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  text-align: center;
  line-height: 1;
  opacity: 0.6;
}

body.column2-layout #sidebar .siderbar-menu li > a .menu-icon::before {
  display: block;
  line-height: 1;
}

body.column2-layout #sidebar .siderbar-menu li > a:hover .menu-icon,
body.column2-layout #sidebar .siderbar-menu li.active > a .menu-icon {
  opacity: 1;
}

body.column2-layout #sidebar .siderbar-menu li > a:hover {
  background-color: var(--nf-account-accent-soft-hover);
  color: var(--nf-account-accent) !important;
}

body.column2-layout #sidebar .siderbar-menu li.active > a {
  background-color: var(--nf-account-accent-soft-active);
  color: var(--nf-account-accent) !important;
}

body.column2-layout #sidebar .siderbar-menu li.active > a:hover {
  color: var(--nf-account-accent) !important;
}

.attributes-menu-wrap ul.sub-menu {
  margin: 0;
  padding: 0;
}

.attributes-menu-wrap ul.sub-menu li {
  margin-bottom: 5px;
}

.attributes-menu-wrap ul.sub-menu li:last-child {
  margin-bottom: 0;
}

.attributes-menu-wrap ul.sub-menu li a,
.top-menu .dropdown-menu .account-nav-link,
.top-menu .drawer-menu .account-nav-link {
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--nf-account-text);
  transition: all 0.2s ease;
}

.attributes-menu-wrap ul.sub-menu li a {
  padding: 9px 16px;
  border: 0;
  background: transparent;
  line-height: 1.2;
}

.attributes-menu-wrap ul.sub-menu li a i {
  margin-right: 0;
  width: 18px;
  min-width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: 0.6;
  font-size: 16px;
  line-height: 1;
  transition: all 0.2s ease;
}

.attributes-menu-wrap ul.sub-menu li a i::before {
  display: block;
  line-height: 1;
}

.attributes-menu-wrap ul.sub-menu li a:hover,
.attributes-menu-wrap ul.sub-menu li.active a,
.top-menu .dropdown-menu .account-nav-link:hover,
.top-menu .drawer-menu .account-nav-link:hover,
#vue-profile-menu .menu-carousel a.active,
#vue-profile-menu .menu-carousel a:hover {
  background: var(--nf-account-accent-soft-hover);
  color: var(--nf-account-accent) !important;
}

.attributes-menu-wrap ul.sub-menu li.active a {
  background: var(--nf-account-accent-soft-active);
}

.attributes-menu-wrap ul.sub-menu li a:hover i,
.attributes-menu-wrap ul.sub-menu li.active a i {
  opacity: 1;
}

.top-menu .dropdown-menu .account-nav-link {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 46px;
  padding: 9px 12px;
}

.top-menu .drawer-menu .drawer-menu-mobile li a.account-nav-link {
  padding: 8px 0;
}

.top-menu .account-nav-link__icon {
  width: 30px;
  height: 30px;
  min-width: 30px;
  flex: 0 0 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9px;
  border: 1px solid var(--nf-account-accent-ring);
  background: var(--nf-account-accent-soft);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 16px 16px;
  color: var(--nf-account-accent);
  font-size: 15px;
}

.top-menu .account-nav-link__text {
  flex: 1 1 auto;
  display: block;
  line-height: 1.25;
}

.top-menu .userprofile .account-trigger-name {
  width: auto;
  max-width: none;
  overflow: visible;
  text-overflow: initial;
  white-space: nowrap;
}

.account-location-label {
  max-width: 300px;
}

.account-profile-avatar {
  width: 100px;
  height: 100px;
}

.wallet-balance-illustration {
  width: 50px;
  height: 50px;
}

.wallet-balance-message {
  max-width: 80%;
}

.wallet-topup-shell {
  max-width: 300px;
  margin: 0 auto;
}

.wallet-topup-payment-logo {
  width: 30px;
  height: 30px;
}

.wallet-topup-submit {
  width: 100%;
}

.wallet-transaction-empty {
  min-height: 200px;
}

.checkout-modal-header--compact {
  padding-bottom: 0 !important;
}

.delivery-address-action__icon {
  font-size: 20px;
}

.search-nav__icon {
  font-size: 20px;
}

.checkout-map-fill {
  width: 100%;
  height: 100%;
}

.checkout-textarea-compact {
  max-height: 150px;
}

.top-menu .account-nav-link--logout .account-nav-link__icon {
  border-color: var(--nf-account-danger-border);
  background: var(--nf-account-danger-surface);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 16px 16px;
  color: var(--nf-account-danger-text);
}

.top-menu .account-nav-link--account .account-nav-link__icon {
  background-image: url("../images/account.png");
}

.top-menu .account-nav-link--orders .account-nav-link__icon {
  background-image: url("../images/orders-icon.png");
}

.top-menu .account-nav-link--addresses .account-nav-link__icon {
  background-image: url("../images/location.png");
  background-size: 14px 14px;
}

.top-menu .account-nav-link--bookings .account-nav-link__icon {
  background-image: url("../images/reserved-table.png");
}

.top-menu .account-nav-link--payments .account-nav-link__icon {
  background-image: url("../images/payments-icon.png");
}

.top-menu .account-nav-link--points .account-nav-link__icon {
  background-image: url("../images/points-icon.png");
}

.top-menu .account-nav-link--wallet .account-nav-link__icon {
  background-image: url("../images/wallet-2.png");
}

.top-menu .account-nav-link--chat .account-nav-link__icon {
  background-image: url("../images/live-chat2.png");
}

.top-menu .account-nav-link--saved .account-nav-link__icon {
  background-image: url("../images/favorites-icon.png");
}

.top-menu .account-nav-link--logout .account-nav-link__icon {
  background-image: url("../images/log-out.png");
}

#vue-profile-menu .menu-carousel a {
  border-radius: 10px;
  padding: 8px 12px;
  font-weight: 600;
  color: var(--nf-account-text);
  transition: all 0.2s ease;
}

#vue-my-order .header_icon._icons,
#vue-my-bookings .header_icon._icons,
#vue-my-points .header_icon._icons {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  border: 1px solid var(--nf-account-line);
  background-color: var(--nf-account-surface-soft);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 28px 28px;
}

#vue-my-order .header_icon .rounded-button-icon,
#vue-my-bookings .header_icon .rounded-button-icon,
#vue-my-points .header_icon .rounded-button-icon {
  width: 24px;
  height: 24px;
  line-height: 24px;
  margin-top: 16px;
  border-radius: 8px;
  border: 1px solid var(--nf-account-line);
  background: var(--nf-account-surface);
}

#vue-my-order .header_icon .rounded-button-icon i,
#vue-my-bookings .header_icon .rounded-button-icon i,
#vue-my-points .header_icon .rounded-button-icon i,
#vue-my-order .dropdown-item i,
#vue-my-bookings .dropdown-item i,
#vue-my-payments .dropdown-item i {
  font-size: 14px;
  color: var(--nf-account-text-faint);
}

#vue-my-order .dropdown-item i,
#vue-my-bookings .dropdown-item i,
#vue-my-payments .dropdown-item i {
  width: 18px;
  text-align: center;
}

#vue-my-payments .payment-item-logo i {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9px;
  border: 1px solid var(--nf-account-line);
  background: var(--nf-account-surface-soft);
  color: var(--nf-account-text-muted);
  font-size: 18px;
}

#vue-my-payments .payment-hero-box,
#vue-my-wallet .wallet-hero-box,
#vue-saved-store .saved-store-hero-box,
#vue-my-order .order-empty-box {
  border: 1px solid var(--nf-account-line);
  border-radius: 12px;
  background: linear-gradient(180deg, var(--nf-account-surface) 0%, var(--nf-account-surface-soft) 100%);
}

#vue-my-payments .payment-hero-box,
#vue-my-wallet .wallet-hero-box,
#vue-saved-store .saved-store-hero-box {
  padding: 8px 10px !important;
}

#vue-my-payments .payment-hero-inline,
#vue-my-wallet .wallet-header-inline,
#vue-saved-store .saved-store-hero-inline {
  gap: 10px;
}

#vue-my-payments .payment-hero-title-wrap h6,
#vue-my-wallet .wallet-header-title-wrap h6,
#vue-saved-store .saved-store-hero-title-wrap h6 {
  font-size: 15px;
  line-height: 1.15;
}

#vue-my-payments .payment-hero-title-wrap p,
#vue-my-wallet .wallet-header-title-wrap p,
#vue-saved-store .saved-store-hero-title-wrap p {
  font-size: 12px;
  line-height: 1.2;
}

#vue-my-payments .payment-add-btn,
#vue-my-wallet .wallet-add-btn,
#vue-saved-store .saved-store-cta-btn,
#vue-my-order .order-empty-cta {
  min-height: 34px;
  border-radius: 9px;
  font-size: 12px;
  padding: 7px 10px;
}

#vue-my-payments .payment-add-btn {
  min-width: 124px;
}

#vue-my-wallet .wallet-add-btn {
  min-width: 112px;
}

#vue-saved-store .saved-store-cta-btn {
  min-width: 126px;
}

#vue-my-order .order-empty-cta {
  min-width: 116px;
}

#vue-my-payments .payment-add-btn--sm {
  min-width: 118px;
}

#vue-my-payments .payment-add-btn--xs {
  min-width: 76px;
  min-height: 32px;
}

#vue-my-wallet .wallet-add-btn--xs,
#vue-saved-store .saved-store-cta-btn--xs {
  min-width: 72px;
  min-height: 32px;
}

#vue-saved-store .saved-store-cta-btn--sm {
  min-width: 122px;
}

#vue-my-wallet .wallet-balance-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--nf-account-info-border-alt);
  background: var(--nf-account-info-surface-alt);
  color: var(--nf-account-info-text-alt);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

#vue-my-wallet .wallet-add-btn-icon {
  font-size: 16px;
  line-height: 1;
}

#vue-my-wallet .wallet-bonus-wrap {
  padding-top: 2px;
}

#vue-my-wallet .wallet-tabs {
  margin-top: 2px;
}

#vue-my-wallet .wallet-tabs .el-tabs__header {
  margin-bottom: 10px;
}

#vue-my-wallet .wallet-tabs .el-tabs__item {
  height: 34px;
  line-height: 34px;
  font-size: 13px;
  padding: 0 12px !important;
}

#vue-my-wallet .wallet-tabs .el-tabs__nav-wrap::after {
  height: 1px;
}

#vue-my-wallet .wallet-topup-dialog {
  --wallet-topup-ink: var(--nf-ink);
  --wallet-topup-muted: var(--nf-account-text-faint);
  --wallet-topup-surface: var(--nf-account-surface);
  --wallet-topup-line: var(--nf-account-line);
  --wallet-topup-line-hover: var(--nf-account-info-border-alt);
  --wallet-topup-shadow-hover: 0 4px 10px rgba(15, 23, 42, 0.04);
  --wallet-topup-success: var(--nf-account-wallet-success);
  --wallet-topup-success-bg: var(--nf-account-success-surface);
  --wallet-topup-success-ring: 0 0 0 1px rgba(22, 163, 74, 0.08);
  color: var(--wallet-topup-ink);
}

#vue-my-wallet .wallet-topup-head {
  text-align: center;
}

#vue-my-wallet .wallet-topup-head h5,
#vue-my-wallet .wallet-topup-section-label h5 {
  font-size: 16px;
  line-height: 1.2;
}

#vue-my-wallet .wallet-topup-head p,
#vue-my-wallet .wallet-topup-note {
  font-size: 11px;
  line-height: 1.45;
  color: var(--wallet-topup-muted);
}

#vue-my-wallet .wallet-topup-amount .el-input-number {
  border-radius: 12px;
}

#vue-my-wallet .wallet-topup-methods {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#vue-my-wallet .wallet-topup-method {
  margin: 0 !important;
  padding: 10px 12px;
  border: 1px solid var(--wallet-topup-line);
  background: var(--wallet-topup-surface);
  cursor: pointer;
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background-color 0.18s ease;
}

#vue-my-wallet .wallet-topup-method:hover {
  border-color: var(--wallet-topup-line-hover);
  box-shadow: var(--wallet-topup-shadow-hover);
}

#vue-my-wallet .wallet-topup-method.selected {
  border-color: var(--wallet-topup-success);
  background: var(--wallet-topup-success-bg);
  box-shadow: var(--wallet-topup-success-ring);
}

#vue-my-wallet .wallet-topup-method-logo {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

#vue-my-wallet .wallet-topup-logo {
  width: 30px;
  height: 30px;
}

#vue-my-wallet .wallet-topup-method-logo i {
  font-size: 20px;
  color: var(--wallet-topup-ink);
}

#vue-my-wallet .wallet-topup-method-copy b {
  font-size: 13px;
  line-height: 1.2;
  font-weight: 700;
}

#vue-my-wallet .wallet-topup-method-copy p {
  font-size: 11px;
  line-height: 1.35;
  color: var(--nf-account-text-faint);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#vue-my-wallet .wallet-topup-method-check i {
  font-size: 18px;
}

#vue-my-wallet .wallet-topup-submit {
  min-height: 40px;
  border-radius: 11px;
}

#vue-my-wallet .wallet-transaction-row {
  border: 0;
  border-bottom: 1px solid var(--nf-account-line-soft);
  border-radius: 6px !important;
  padding: 9px 10px !important;
  box-shadow: none;
  margin-bottom: 0 !important;
}

#vue-my-wallet .wallet-transaction-main,
#vue-my-wallet .wallet-transaction-left {
  min-width: 0;
}

#vue-my-wallet .wallet-transaction-left {
  padding-right: 10px;
  flex: 1 1 auto;
}

#vue-my-wallet .wallet-transaction-title {
  font-size: 12px;
  line-height: 1.25;
  font-weight: 500;
  color: var(--nf-account-text-soft);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#vue-my-wallet .wallet-transaction-meta {
  margin-top: 2px !important;
  font-size: 10px;
  line-height: 1.2;
  color: var(--nf-account-text-ghost);
}

#vue-my-wallet .wallet-transaction-right {
  display: flex;
  align-items: flex-end;
  flex: 0 0 auto;
}

#vue-my-wallet .wallet-transaction-value {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

#vue-my-wallet .wallet-transaction-row:last-child {
  border-bottom: 0;
}

#vue-saved-store .saved-store-empty-wrap {
  margin-bottom: 8px;
}

#vue-saved-store .saved-store-empty-card {
  border: 1px dashed var(--nf-text-faint);
  border-radius: 12px;
  background: var(--nf-account-surface);
}

#vue-saved-store .saved-store-empty-card h6 {
  font-size: 15px;
}

#vue-saved-store .saved-store-empty-card p {
  margin-top: 6px !important;
  font-size: 12px;
}

#vue-saved-store .saved-store-media {
  border-radius: 8px;
  overflow: hidden;
  background: var(--nf-account-surface-soft);
}

#vue-saved-store .saved-store-image,
#vue-saved-store .saved-store-image img {
  display: block;
  width: 100%;
  height: 160px;
  object-fit: cover;
}

#vue-saved-store .saved-store-media .layer-grey {
  background: var(--nf-account-overlay-surface-soft);
  backdrop-filter: blur(1px);
}

#vue-saved-store .saved-store-status-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 10;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--nf-account-danger-border);
  background: var(--nf-account-overlay-surface);
  color: var(--nf-account-danger-text);
  font-size: 10px;
  font-weight: 700;
}

#vue-saved-store .saved-store-fav {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 11;
}

#vue-saved-store .saved-store-fav .btn.btn-circle {
  width: 32px;
  height: 32px;
  min-width: 32px;
  padding: 0;
  border: 1px solid var(--nf-account-line);
  background: var(--nf-account-overlay-surface) !important;
}

#vue-saved-store .saved-store-fav .btn.btn-circle .zmdi {
  font-size: 16px;
}

#vue-saved-store .saved-store-content {
  padding-top: 8px;
}

#vue-saved-store .saved-store-name {
  font-size: 15px;
  line-height: 1.25;
}

#vue-saved-store .saved-store-cuisine-line {
  margin-top: 4px !important;
  color: var(--nf-account-text-faint);
  min-height: 18px;
}

#vue-saved-store .saved-store-cuisine-line .a-12 {
  font-size: 12px;
}

#vue-saved-store .saved-store-meta-row {
  margin-top: 8px;
}

#vue-saved-store .saved-store-rating,
#vue-saved-store .saved-store-eta {
  font-size: 12px;
  line-height: 1.2;
  color: var(--nf-account-text-soft);
}

#vue-saved-store .saved-store-rating span {
  color: var(--nf-account-text-faint);
}

#vue-saved-store .saved-store-delivery-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid var(--nf-account-success-border);
  background: var(--nf-account-success-surface);
  color: var(--nf-account-success-text);
  font-size: 10px;
  font-weight: 700;
}

#vue-saved-store .make-grey .saved-store-card {
  opacity: 0.92;
}

#vue-saved-store .make-grey .saved-store-name {
  color: var(--nf-account-text-faint);
}

#vue-my-order .order-toolbar-row {
  margin-bottom: 10px !important;
}

#vue-my-order .order-search-wrap {
  padding-left: 0;
}

#vue-my-order .order-search-box {
  max-width: 460px;
}

#vue-my-order .order-search-box .form-control.form-control-text {
  min-height: 40px;
  border-radius: 10px;
  font-size: 13px;
  padding-right: 34px;
}

#vue-my-order .order-empty-card {
  border: 0 !important;
}

#vue-my-order .order-empty-box {
  padding: 10px !important;
}

#vue-my-order .order-empty-text h5 {
  font-size: 15px;
  margin-bottom: 3px;
}

#vue-my-order .order-empty-text p {
  font-size: 12px;
}

#vue-my-order .order-item-row {
  padding: 10px !important;
}

#vue-my-order .order-merchant-logo {
  width: 54px;
  height: 54px;
  object-fit: cover;
}

#vue-my-order .order-merchant-head {
  gap: 6px;
}

#vue-my-order .order-merchant-name {
  font-size: 14px;
  line-height: 1.2;
}

#vue-my-order .order-merchant-address {
  margin-top: 3px !important;
  color: var(--nf-account-text-faint);
  font-size: 12px;
  line-height: 1.25;
}

#vue-my-order .order-service-badge,
#vue-my-order .order-status-badge,
#vue-my-order .order-items-badge,
#vue-my-order .order-panel-overview .badge {
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  text-transform: none;
}

#vue-my-order .order-summary-col {
  padding-left: 18px !important;
}

#vue-my-order .order-id-line {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

#vue-my-order .order-items-badge {
  margin-top: 5px !important;
}

#vue-my-order .order-meta-wrap {
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}

#vue-my-order .order-total-line,
#vue-my-order .order-date-line {
  font-size: 12px;
  line-height: 1.3;
}

#vue-my-order .order-actions-btn,
#vue-my-order .order-panel-close-btn {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid var(--nf-account-line);
  background: var(--nf-account-surface-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

#vue-my-order .order-actions-btn i,
#vue-my-order .order-panel-close-btn i {
  font-size: 16px;
  color: var(--nf-account-text-faint);
}

#vue-my-order .dropdown-actions {
  border-radius: 10px;
  border: 1px solid var(--nf-account-line);
  box-shadow: var(--nf-account-shadow-md);
}

#vue-my-order .order-details-panel {
  width: min(400px, 100vw);
  max-width: 100vw;
  transform: translateX(102%);
  transition: transform 0.24s ease;
  border-left: 1px solid var(--nf-account-line);
  box-shadow: var(--nf-account-shadow-lg);
  padding: 12px 14px 16px !important;
  background: var(--nf-account-surface);
}

#vue-my-order .order-details-panel.open {
  transform: translateX(0);
}

#vue-my-order .order-panel-close-btn {
  position: sticky;
  top: 0;
  right: 0;
  z-index: 3;
  margin-left: auto;
}

#vue-my-order .order-panel-merchant,
#vue-my-order .order-panel-totals,
#vue-my-order .order-panel-paidwith {
  border: 1px solid var(--nf-account-line);
  border-radius: 10px;
  background: var(--nf-account-surface-soft);
}

#vue-my-order .order-panel-merchant {
  padding: 9px 10px;
}

#vue-my-order .order-panel-merchant p {
  font-size: 12px;
}

#vue-my-order .order-panel-merchant h5 {
  font-size: 16px;
  line-height: 1.2;
}

#vue-my-order .order-panel-refund h5,
#vue-my-order .order-panel-summary-title {
  font-size: 14px;
  margin-bottom: 8px !important;
}

#vue-my-order .order-panel-refund-card {
  border: 1px solid var(--nf-account-line);
  border-radius: 8px !important;
  background: var(--nf-account-surface) !important;
}

#vue-my-order .order-panel-refund-card p {
  font-size: 11px;
  line-height: 1.3;
}

#vue-my-order .order-details-panel .items {
  padding: 9px 0;
  border-bottom: 1px solid var(--nf-line-soft);
}

#vue-my-order .order-panel-item:last-of-type {
  border-bottom: 0;
}

#vue-my-order .order-panel-overview h6,
#vue-my-order .order-panel-customer h6 {
  font-size: 13px;
  line-height: 1.25;
}

#vue-my-order .order-panel-line-items,
#vue-my-order .order-panel-addon-items {
  display: flex;
  flex-wrap: nowrap;
  margin: 0 !important;
}

#vue-my-order .order-panel-line-items {
  align-items: flex-start;
}

#vue-my-order .order-panel-line-items > .col-9 {
  flex: 1 1 auto;
  max-width: calc(100% - 72px);
  padding-left: 0 !important;
  padding-right: 8px;
}

#vue-my-order .order-panel-line-items > .col-3.quantity {
  flex: 0 0 64px;
  max-width: 64px;
  width: 64px;
  padding: 0 !important;
  text-align: right;
}

#vue-my-order .order-panel-line-items p,
#vue-my-order .order-panel-addon-items p {
  font-size: 12px;
  line-height: 1.3;
}

#vue-my-order .order-panel-addon-items > .col-12 {
  flex: 1 1 auto;
  max-width: 100%;
  padding-left: 0 !important;
  padding-right: 0;
}

#vue-my-order .order-panel-line-items .quantity {
  width: auto;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

#vue-my-order .order-panel-line-items .quantity p {
  font-weight: 600;
  color: var(--nf-ink);
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

#vue-my-order .order-panel-totals,
#vue-my-order .order-panel-paidwith {
  padding: 8px 10px;
}

#vue-my-order .order-panel-totals > div,
#vue-my-order .order-panel-paidwith > div {
  font-size: 12px;
}

#vue-my-order .order-panel-paidwith hr {
  margin: 6px 0 8px;
}

#vue-my-order .order-panel-points {
  margin: 0 0 8px !important;
  font-size: 12px;
  color: var(--nf-account-text-soft);
}

#vue-my-order .order-panel-actions {
  margin-bottom: 6px !important;
}

#vue-my-order .order-panel-action-row {
  margin-left: -4px;
  margin-right: -4px;
}

#vue-my-order .order-panel-action-row > .col {
  padding-left: 4px;
  padding-right: 4px;
}

#vue-my-order .order-panel-action-row.single-action > .col:last-child {
  flex: 0 0 100%;
  max-width: 100%;
}

#vue-my-order .order-panel-action-btn {
  min-height: 34px;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
}

#vue-my-order .order-panel-track-btn {
  background: var(--nf-account-track-dark);
  border-color: var(--nf-account-track-dark);
}

#vue-my-order .order-panel-buyagain-btn {
  box-shadow: var(--nf-account-shadow-success);
}

@media (max-width: 768px) {
  .account-page-title {
    padding: 5px 10px;
    min-height: 34px;
    font-size: 13px;
  }

  .account-page-title__icon {
    width: 24px;
    height: 24px;
    min-width: 24px;
    border-radius: 8px;
    font-size: 14px;
  }
}

@media (max-width: 991px) {
  #vue-my-address .address-hero-mobile .address-add-btn,
  #location-addresses .address-hero-mobile .address-add-btn {
    width: auto;
    min-width: 78px;
    margin-top: 0 !important;
  }

  #vue-my-address .address-slot.card.address-item-card,
  #location-addresses .address-slot.card.address-item-card,
  #vue-my-payments .card-listing.payment-item-card {
    min-height: 0;
  }

  #vue-my-address .address-hero-box,
  #location-addresses .address-hero-box,
  #vue-my-payments .payment-hero-box,
  #vue-my-wallet .wallet-hero-box,
  #vue-saved-store .saved-store-hero-box {
    padding: 8px !important;
  }

  #vue-my-address .address-card-actions .btn.small,
  #location-addresses .address-card-actions .btn.small,
  #vue-my-payments .payment-card-actions .btn.small {
    font-size: 11px;
  }

  #vue-my-payments .payment-hero-mobile .payment-add-btn,
  #vue-my-wallet .wallet-add-btn,
  #vue-saved-store .saved-store-cta-btn {
    width: auto;
    min-width: 76px;
    margin-top: 0 !important;
  }

  #vue-my-wallet .wallet-balance-badge {
    min-height: 30px;
    padding: 0 8px;
    font-size: 12px;
  }

  #vue-my-wallet .wallet-bonus-wrap {
    padding-left: 0;
    margin-top: 8px;
  }

  #vue-my-wallet .wallet-tabs .el-tabs__item {
    height: 32px;
    line-height: 32px;
    font-size: 12px;
    padding: 0 10px !important;
  }

  #vue-my-wallet .wallet-topup-head h5,
  #vue-my-wallet .wallet-topup-section-label h5 {
    font-size: 15px;
  }

  #vue-my-wallet .wallet-topup-method {
    padding: 9px 10px;
  }

  #vue-my-wallet .wallet-topup-method-logo {
    width: 28px;
    height: 28px;
  }

  #vue-my-wallet .wallet-topup-logo {
    width: 26px;
    height: 26px;
  }

  #vue-my-wallet .wallet-topup-method-copy b {
    font-size: 12px;
  }

  #vue-my-wallet .wallet-topup-method-copy p,
  #vue-my-wallet .wallet-transaction-meta {
    font-size: 10px;
  }

  #vue-my-wallet .wallet-topup-submit {
    min-height: 38px;
  }

  #vue-my-wallet .wallet-transaction-row {
    padding: 8px !important;
    margin-bottom: 0 !important;
  }

  #vue-my-wallet .wallet-transaction-title,
  #vue-my-wallet .wallet-transaction-value {
    font-size: 12px;
  }

  #vue-saved-store .saved-store-card {
    border-radius: 9px;
  }

  #vue-saved-store .saved-store-media {
    border-radius: 7px;
  }

  #vue-saved-store .saved-store-image {
    height: 148px !important;
  }

  #vue-saved-store .saved-store-fav .btn.btn-circle {
    width: 30px;
    height: 30px;
    min-width: 30px;
  }

  #vue-my-order .order-search-box {
    max-width: 100%;
  }

  #vue-my-order .order-item-row {
    padding: 9px !important;
  }

  #vue-my-order .order-item-row > .col {
    flex: 0 0 100%;
    max-width: 100%;
  }

  #vue-my-order .order-summary-col {
    padding-left: 0 !important;
    margin-top: 8px;
  }

  #vue-my-order .order-meta-col {
    margin-top: 8px;
  }

  #vue-my-order .order-meta-wrap {
    align-items: center;
  }

  #vue-my-order .order-empty-cta {
    width: auto;
    min-width: 100px;
    margin-top: 8px;
  }

  #vue-my-order .order-details-panel {
    width: 100vw;
    border-left: 0;
    padding: 10px 12px 14px !important;
  }

  #vue-my-order .order-panel-line-items .col-3.quantity,
  #vue-my-order .order-panel-line-items .col-9 {
    padding-right: 6px;
    padding-left: 6px;
  }

  #vue-my-order .order-panel-line-items .quantity {
    padding-right: 6px;
    padding-left: 0;
  }

  #vue-my-order .order-panel-addon-items > .col-12 {
    padding-right: 6px;
    padding-left: 0 !important;
  }

  #vue-my-order .order-panel-action-btn {
    min-height: 32px;
    font-size: 11px;
  }
}
