/* =====================================================
   Vizard Account Dashboard — dashboard.css  v1.3.0
   WoodMart + WooCommerce + Elementor compatible
   Fixes: gaps removed, mobile layout fixed
   ===================================================== */

:root {
  --vad-primary:    #1a6ef5;
  --vad-accent:     #0d47a1;
  --vad-sidebar-bg: #ffffff;
  --vad-white:      #ffffff;
  --vad-border:     #e8ecf2;
  --vad-text:       #1a1f36;
  --vad-muted:      #6b7280;
  --vad-radius:     12px;
  --vad-shadow:     0 2px 12px rgba(26,111,245,.07);
  --vad-transition: .18s ease;
}

/* ══════════════════════════════════════════
   FIX: Elementor/WoodMart page layout gaps
   The two purple-arrow gaps come from Elementor
   column padding and WoodMart section margins.
══════════════════════════════════════════ */
.woocommerce-account .woocommerce {
  margin-top: 0 !important;
}
/* Remove Elementor default column gaps that create empty space */
.woocommerce-account .elementor-widget-woocommerce-my-account-content > .elementor-widget-container,
.woocommerce-account .elementor-widget-container {
  padding: 0 !important;
}
/* Fix WoodMart section top/bottom margin causing gaps */
.woocommerce-account .wd-section,
.woocommerce-account .elementor-section {
  margin-bottom: 0 !important;
}
.woocommerce-account .woocommerce-MyAccount-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* ══════════════════════════════════════════
   MOBILE FIX — prevent content overflow
══════════════════════════════════════════ */

/* Force the WooCommerce account wrapper to be a proper flex/block */
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
}

/* Elementor layout — make columns stack on mobile */
@media (max-width: 767px) {
  /* Force Elementor columns to stack vertically */
  .woocommerce-account .elementor-column,
  .woocommerce-account .elementor-col-25,
  .woocommerce-account .elementor-col-75,
  .woocommerce-account .elementor-col-33,
  .woocommerce-account .elementor-col-66 {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
  .woocommerce-account .elementor-row,
  .woocommerce-account .e-con-inner {
    flex-wrap: wrap !important;
  }
  /* Dashboard content must be full width on mobile */
  .woocommerce-account .woocommerce-MyAccount-content {
    padding: 0 !important;
    margin: 0 !important;
    overflow-x: hidden !important;
    max-width: 100vw !important;
  }
  /* Prevent horizontal scroll */
  .woocommerce-account .woocommerce {
    overflow-x: hidden !important;
  }
}

/* ══════════════════════════════════════════
   DASHBOARD WRAPPER
══════════════════════════════════════════ */
.vad-dashboard,
.vad-dashboard * {
  box-sizing: border-box;
}
.vad-dashboard {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 0 0 32px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  width: 100%;
  min-width: 0;
  overflow-x: hidden;
}

/* ══════════════════════════════════════════
   WELCOME BANNER
══════════════════════════════════════════ */
.vad-welcome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.vad-welcome__title {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--vad-text);
  margin: 0 0 3px;
  line-height: 1.3;
}
.vad-welcome__title span { color: var(--vad-primary); }
.vad-welcome__sub {
  font-size: .84rem;
  color: var(--vad-muted);
  margin: 0;
}
.vad-member-since {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .76rem;
  color: var(--vad-muted);
  background: var(--vad-white);
  border: 1px solid var(--vad-border);
  border-radius: 50px;
  padding: 5px 12px;
  white-space: nowrap;
}

/* ══════════════════════════════════════════
   STATS CARDS
══════════════════════════════════════════ */
.vad-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  width: 100%;
}

.vad-stat-card {
  background: var(--vad-white);
  border: 1px solid var(--vad-border);
  border-radius: var(--vad-radius);
  padding: 16px;
  box-shadow: var(--vad-shadow);
  transition: box-shadow var(--vad-transition), transform var(--vad-transition);
  min-width: 0;
}
.vad-stat-card:hover {
  box-shadow: 0 6px 20px rgba(26,111,245,.13);
  transform: translateY(-2px);
}
.vad-stat-card__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.vad-stat-card__info {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  flex: 1;
}
.vad-stat-card__label {
  font-size: .68rem;
  color: var(--vad-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.vad-stat-card__value {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--vad-text);
  line-height: 1;
}
.vad-stat-card__value--blue { color: var(--vad-primary); }
.vad-stat-card__link,
.vad-stat-card__sub {
  font-size: .72rem;
  color: var(--vad-muted);
  text-decoration: none;
}
.vad-stat-card__link:hover { color: var(--vad-primary); text-decoration: underline; }

.vad-stat-card__icon {
  width: 42px; height: 42px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.vad-stat-card__icon svg { width: 20px; height: 20px; }
.vad-stat-card__icon--blue   { background: #dbeafe; color: #1d4ed8; }
.vad-stat-card__icon--pink   { background: #fce7f3; color: #db2777; }
.vad-stat-card__icon--yellow { background: #fef9c3; color: #ca8a04; }
.vad-stat-card__icon--teal   { background: #ccfbf1; color: #0d9488; }

/* ══════════════════════════════════════════
   MAIN GRID — Orders + Account Summary
══════════════════════════════════════════ */
.vad-main-grid {
  display: grid;
  grid-template-columns: 1fr 290px;
  gap: 16px;
  align-items: start;
  width: 100%;
}

/* ── Panels ── */
.vad-panel {
  background: var(--vad-white);
  border: 1px solid var(--vad-border);
  border-radius: var(--vad-radius);
  box-shadow: var(--vad-shadow);
  overflow: hidden;
  min-width: 0;
}
.vad-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--vad-border);
  gap: 8px;
}
.vad-panel__title {
  font-size: .92rem;
  font-weight: 700;
  color: var(--vad-text);
  margin: 0;
}
.vad-panel__more {
  font-size: .76rem;
  color: var(--vad-primary);
  text-decoration: none;
  font-weight: 500;
  white-space: nowrap;
  flex-shrink: 0;
}
.vad-panel__more:hover { text-decoration: underline; }

/* ── Orders ── */
.vad-orders-list { padding: 4px 0; }
.vad-order-row {
  display: grid;
  grid-template-columns: 44px 1fr auto auto 18px;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  text-decoration: none;
  color: inherit;
  transition: background var(--vad-transition);
  border-bottom: 1px solid var(--vad-border);
}
.vad-order-row:last-child { border-bottom: none; }
.vad-order-row:hover { background: #f8faff; }

.vad-order-row__img {
  width: 42px; height: 42px;
  border-radius: 7px; overflow: hidden;
  border: 1px solid var(--vad-border); flex-shrink: 0;
}
.vad-order-row__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vad-order-row__img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: #f1f5f9; color: #94a3b8;
}
.vad-order-row__img-placeholder svg { width: 16px; height: 16px; }
.vad-order-row__info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.vad-order-row__num  { font-size: .83rem; font-weight: 600; color: var(--vad-text); }
.vad-order-row__date { font-size: .7rem; color: var(--vad-muted); }
.vad-order-row__total { font-size: .86rem; font-weight: 700; color: var(--vad-text); white-space: nowrap; }
.vad-order-row__arrow { font-size: 1rem; color: #cbd5e1; }

/* ── Badges ── */
.vad-badge {
  display: inline-flex; align-items: center;
  font-size: .68rem; font-weight: 600;
  padding: 3px 9px; border-radius: 50px; white-space: nowrap;
}
.vad-badge--delivered  { background: #dcfce7; color: #16a34a; }
.vad-badge--shipped    { background: #dbeafe; color: #2563eb; }
.vad-badge--processing { background: #fef9c3; color: #b45309; }
.vad-badge--cancelled  { background: #fee2e2; color: #dc2626; }
.vad-badge--pending    { background: #f3f4f6; color: #6b7280; }
.vad-badge--hold       { background: #ede9fe; color: #7c3aed; }
.vad-badge--refunded   { background: #fce7f3; color: #db2777; }
.vad-badge--failed     { background: #fee2e2; color: #991b1b; }
.vad-badge--default    { background: #f1f5f9; color: #64748b; }

/* ── Account Summary ── */
.vad-summary-list { padding: 6px 18px; }
.vad-summary-row {
  display: flex; justify-content: space-between;
  gap: 10px; padding: 9px 0;
  border-bottom: 1px solid var(--vad-border); font-size: .8rem;
}
.vad-summary-row:last-child { border-bottom: none; }
.vad-summary-row__key { color: var(--vad-muted); font-weight: 500; flex-shrink: 0; }
.vad-summary-row__val { color: var(--vad-text); font-weight: 500; text-align: right; word-break: break-word; }

/* ── Edit Profile button ── */
.vad-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 6px; padding: 9px 16px; border-radius: 8px;
  font-size: .83rem; font-weight: 600; text-decoration: none;
  cursor: pointer; transition: all var(--vad-transition);
  border: 2px solid transparent; line-height: 1.4;
}
.vad-btn--full { display: flex; margin: 6px 18px 18px; width: calc(100% - 36px); }
.vad-btn--outline {
  border-color: var(--vad-border); color: var(--vad-text); background: transparent;
}
.vad-btn--outline:hover { border-color: var(--vad-primary); color: var(--vad-primary); background: #eef4ff; }

.vad-empty { padding: 28px 18px; text-align: center; color: var(--vad-muted); font-size: .86rem; }

/* ══════════════════════════════════════════════════════
   SIDEBAR — User Card
══════════════════════════════════════════════════════ */
.vad-user-card {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--vad-primary);
  border-radius: 12px 12px 0 0;
  padding: 16px 14px 18px;
}
.vad-user-card__avatar {
  width: 48px; height: 48px; border-radius: 50%;
  overflow: hidden; flex-shrink: 0;
  border: 2px solid rgba(255,255,255,.4);
  background: rgba(255,255,255,.15);
}
.vad-user-card__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vad-user-card__info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.vad-user-card__greeting { font-size: .7rem; color: rgba(255,255,255,.75); font-weight: 500; }
.vad-user-card__name {
  font-size: .78rem; color: #fff; font-weight: 600;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 130px;
}
.vad-user-card__badge {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: .66rem; font-weight: 700; color: #fbbf24; margin-top: 2px;
}

/* ══════════════════════════════════════════════════════
   SIDEBAR — Navigation
══════════════════════════════════════════════════════ */
.woocommerce-MyAccount-navigation {
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--vad-border);
  overflow: hidden;
  box-shadow: var(--vad-shadow);
}
.woocommerce-MyAccount-navigation ul,
.woocommerce-MyAccount-navigation nav ul,
.woocommerce-MyAccount-navigation ul.wd-nav-my-acc {
  list-style: none !important;
  padding: 6px 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
.woocommerce-MyAccount-navigation ul li,
.woocommerce-MyAccount-navigation nav ul li {
  border-bottom: 1px solid #f3f4f6 !important;
  margin: 0 !important; padding: 0 !important;
  list-style: none !important;
}
.woocommerce-MyAccount-navigation ul li:last-child { border-bottom: none !important; }

/* Nav links */
.woocommerce-MyAccount-navigation ul li a,
.woocommerce-MyAccount-navigation nav ul li a {
  display: flex !important; align-items: center !important;
  gap: 10px !important; padding: 11px 16px !important;
  font-size: .855rem !important; font-weight: 500 !important;
  color: #374151 !important; text-decoration: none !important;
  border-left: 3px solid transparent !important; line-height: 1.4 !important;
  transition: background .15s, color .15s !important;
}
.woocommerce-MyAccount-navigation ul li a:hover {
  background: #eef4ff !important;
  color: var(--vad-primary) !important;
  border-left-color: var(--vad-primary) !important;
}
.woocommerce-MyAccount-navigation ul li.is-active > a,
.woocommerce-MyAccount-navigation ul li.wd-active > a {
  background: #eef4ff !important;
  color: var(--vad-primary) !important;
  font-weight: 700 !important;
  border-left-color: var(--vad-primary) !important;
}

/* Icons via ::before */
.woocommerce-MyAccount-navigation ul li a::before,
.woocommerce-MyAccount-navigation nav ul li a::before {
  content: '' !important; display: inline-block !important;
  width: 17px !important; height: 17px !important; flex-shrink: 0 !important;
  background-size: contain !important; background-repeat: no-repeat !important;
  background-position: center !important; opacity: .5 !important; transition: opacity .15s !important;
}
.woocommerce-MyAccount-navigation ul li a:hover::before,
.woocommerce-MyAccount-navigation ul li.is-active a::before,
.woocommerce-MyAccount-navigation ul li.wd-active a::before { opacity: 1 !important; }

.woocommerce-MyAccount-navigation-link--dashboard a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a6ef5' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7'/%3E%3Crect x='14' y='3' width='7' height='7'/%3E%3Crect x='14' y='14' width='7' height='7'/%3E%3Crect x='3' y='14' width='7' height='7'/%3E%3C/svg%3E") !important;
  opacity: 1 !important;
}
.woocommerce-MyAccount-navigation-link--orders a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 5H7a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V7a2 2 0 0 0-2-2h-2'/%3E%3Crect x='9' y='3' width='6' height='4' rx='2'/%3E%3C/svg%3E") !important;
}
.woocommerce-MyAccount-navigation-link--downloads a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E") !important;
}
.woocommerce-MyAccount-navigation-link--edit-address a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") !important;
}
.woocommerce-MyAccount-navigation-link--payment-methods a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='1' y='4' width='22' height='16' rx='2' ry='2'/%3E%3Cline x1='1' y1='10' x2='23' y2='10'/%3E%3C/svg%3E") !important;
}
.woocommerce-MyAccount-navigation-link--edit-account a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E") !important;
}
.woocommerce-MyAccount-navigation-link--wishlist a::before,
.woocommerce-MyAccount-navigation-link--yith-wcwl-wishlist a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") !important;
}
.woocommerce-MyAccount-navigation-link--customer-logout a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'/%3E%3Cpolyline points='16 17 21 12 16 7'/%3E%3Cline x1='21' y1='12' x2='9' y2='12'/%3E%3C/svg%3E") !important;
}
.woocommerce-MyAccount-navigation .wd-nav-icon,
.woocommerce-MyAccount-navigation .wd-icon { display: none !important; }

/* ══════════════════════════════════════════════════════
   SIDEBAR — Upgrade Card
══════════════════════════════════════════════════════ */
.vad-upgrade-card {
  background: #eef4ff;
  border-top: 1px solid #c7d9fd;
  padding: 16px;
  text-align: center;
}
.vad-upgrade-card__icon {
  width: 38px; height: 38px; background: var(--vad-primary);
  border-radius: 50%; display: flex; align-items: center;
  justify-content: center; margin: 0 auto 8px; color: #fff;
}
.vad-upgrade-card__title { font-size: .84rem; font-weight: 700; color: var(--vad-text); margin: 0 0 4px; }
.vad-upgrade-card__desc  { font-size: .73rem; color: var(--vad-muted); margin: 0 0 12px; line-height: 1.5; }
.vad-upgrade-card__btn {
  display: block; background: var(--vad-primary); color: #fff;
  border-radius: 8px; padding: 9px 14px;
  font-size: .82rem; font-weight: 700; text-decoration: none; transition: background .15s;
}
.vad-upgrade-card__btn:hover { background: var(--vad-accent); color: #fff; }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width: 900px) {
  .vad-main-grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .vad-stats { grid-template-columns: repeat(2, 1fr); }
  .vad-welcome__title { font-size: 1.1rem; }
  .vad-order-row { grid-template-columns: 38px 1fr auto; }
  .vad-order-row__total,
  .vad-order-row__arrow { display: none; }
  .vad-dashboard { gap: 14px; }
  /* Mobile stat cards compact */
  .vad-stat-card { padding: 12px; }
  .vad-stat-card__value { font-size: 1.3rem; }
}
@media (max-width: 400px) {
  .vad-stats { grid-template-columns: 1fr; }
}
