/* ============================================================
   LBWO — Vendor Profile, Directory, Products, Dashboard CSS
   ============================================================ */

/* ── Directory grid ── */
.lbwo-vendor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
}

/* ── Vendor card ── */
.lbwo-vendor-card {
  background: var(--lbwo-white);
  border: 1px solid var(--lbwo-border);
  border-radius: var(--lbwo-radius);
  overflow: hidden;
  text-decoration: none;
  color: var(--lbwo-text);
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--lbwo-transition), transform var(--lbwo-transition);
  box-shadow: var(--lbwo-shadow);
}
.lbwo-vendor-card:hover { box-shadow: var(--lbwo-shadow-lg); transform: translateY(-3px); color: var(--lbwo-text); }
.lbwo-vendor-card__cover {
  height: 140px;
  background: linear-gradient(135deg, var(--lbwo-green-dark), var(--lbwo-green));
  background-size: cover;
  background-position: center;
  position: relative;
}
.lbwo-vendor-card__logo {
  position: absolute;
  bottom: -22px;
  left: 16px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 3px solid var(--lbwo-white);
  object-fit: cover;
  background: var(--lbwo-white);
}
.lbwo-vendor-card__body { padding: 32px 16px 12px; flex: 1; }
.lbwo-vendor-card__header { display: flex; align-items: flex-start; gap: 8px; flex-wrap: wrap; }
.lbwo-vendor-card__name { margin: 0 0 4px; font-size: 1.05rem; font-weight: 700; }
.lbwo-vendor-card__category { display: inline-block; background: var(--lbwo-bg); color: var(--lbwo-muted); font-size: .75rem; padding: 2px 8px; border-radius: 999px; margin-bottom: 4px; }
.lbwo-vendor-card__city { display: flex; align-items: center; gap: 4px; font-size: .82rem; color: var(--lbwo-muted); margin-bottom: 6px; }
.lbwo-vendor-card__desc { font-size: .85rem; color: var(--lbwo-muted); margin: 0; }
.lbwo-vendor-card__footer { padding: 10px 16px; border-top: 1px solid var(--lbwo-border); background: var(--lbwo-bg); }
.lbwo-vendor-card__cta { font-size: .85rem; font-weight: 600; color: var(--lbwo-green); }

/* ── Badges ── */
.lbwo-badges { display: inline-flex; gap: 4px; flex-wrap: wrap; }
.lbwo-badge { display: inline-flex; align-items: center; gap: 3px; padding: 2px 8px; border-radius: 999px; font-size: .72rem; font-weight: 700; }
.lbwo-badge--verified    { background: #e0f2fe; color: #0369a1; }
.lbwo-badge--top_seller  { background: #fef9c3; color: #854d0e; }
.lbwo-badge--premium     { background: #f3e8ff; color: #6b21a8; }

/* ── Profile ── */
.lbwo-profile { max-width: 860px; margin: 0 auto; }
.lbwo-profile__hero { position: relative; margin-bottom: 16px; }
.lbwo-profile__cover { height: 220px; background: linear-gradient(135deg, var(--lbwo-green-dark), var(--lbwo-green)); background-size: cover; background-position: center; border-radius: var(--lbwo-radius); }
.lbwo-profile__identity { display: flex; align-items: flex-end; gap: 16px; padding: 0 16px; margin-top: -40px; position: relative; z-index: 1; flex-wrap: wrap; }
.lbwo-profile__logo { width: 90px; height: 90px; border-radius: 50%; border: 4px solid var(--lbwo-white); object-fit: cover; background: var(--lbwo-white); box-shadow: var(--lbwo-shadow); flex-shrink: 0; }
.lbwo-profile__meta { padding-bottom: 4px; }
.lbwo-profile__name { margin: 0 0 4px; font-size: 1.5rem; font-weight: 800; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.lbwo-profile__category { display: inline-block; background: var(--lbwo-bg); color: var(--lbwo-muted); font-size: .8rem; padding: 2px 10px; border-radius: 999px; margin-bottom: 4px; }
.lbwo-profile__city { display: block; font-size: .85rem; color: var(--lbwo-muted); }
.lbwo-profile__actions { display: flex; gap: 12px; margin: 20px 0; flex-wrap: wrap; }
.lbwo-profile__section { margin: 28px 0; }
.lbwo-profile__description { color: var(--lbwo-text); line-height: 1.7; }
.lbwo-profile__info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.lbwo-info-block { background: var(--lbwo-bg); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius-sm); padding: 14px 16px; }
.lbwo-info-block__title { font-size: .85rem; font-weight: 700; margin: 0 0 6px; color: var(--lbwo-muted); }
.lbwo-info-block a { color: var(--lbwo-green-dark); text-decoration: none; font-size: .9rem; }
.lbwo-info-block a:hover { text-decoration: underline; }
.lbwo-section-title { display: flex; align-items: center; gap: 8px; font-size: 1.15rem; font-weight: 700; margin-bottom: 16px; padding-bottom: 8px; border-bottom: 2px solid var(--lbwo-border); }
.lbwo-section-title__badge { font-size: 1.3rem; }

/* ── Product grid & cards ── */
.lbwo-product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.lbwo-product-grid--daily .lbwo-product-card { border: 2px solid var(--lbwo-warning); }
.lbwo-product-card { background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius); overflow: hidden; transition: box-shadow var(--lbwo-transition), transform var(--lbwo-transition); display: flex; flex-direction: column; }
.lbwo-product-card:hover { box-shadow: var(--lbwo-shadow); transform: translateY(-2px); }
.lbwo-product-card__img-wrap { position: relative; }
.lbwo-product-card__img { width: 100%; height: 160px; object-fit: cover; display: block; }
.lbwo-product-card__daily-badge { position: absolute; top: 8px; left: 8px; background: var(--lbwo-warning); color: #fff; font-size: .72rem; font-weight: 700; padding: 3px 8px; border-radius: 999px; }
.lbwo-product-card__body { padding: 12px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.lbwo-product-card__name { font-size: .95rem; font-weight: 700; margin: 0; }
.lbwo-product-card__desc { font-size: .82rem; color: var(--lbwo-muted); margin: 0; flex: 1; }
.lbwo-product-card__footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 8px; border-top: 1px solid var(--lbwo-border); }
.lbwo-product-card__price { font-size: 1rem; font-weight: 800; color: var(--lbwo-green-dark); }

/* ── Social links ── */
.lbwo-social-links { display: flex; gap: 8px; flex-wrap: wrap; }
.lbwo-social-link { display: inline-block; padding: 5px 14px; border-radius: 999px; font-size: .82rem; font-weight: 600; text-decoration: none; }
.lbwo-social-link--fb { background: #1877f2; color: #fff; }
.lbwo-social-link--ig { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); color: #fff; }

/* ── Order success ── */
.lbwo-order-success { text-align: center; padding: 48px 24px; max-width: 480px; margin: 0 auto; }
.lbwo-order-success__icon { font-size: 4rem; display: block; margin-bottom: 16px; }
.lbwo-order-success h2 { font-size: 1.5rem; margin-bottom: 12px; }
.lbwo-order-success p { color: var(--lbwo-muted); margin-bottom: 24px; }

/* ── VENDOR DASHBOARD ── */
.lbwo-dashboard { display: grid; grid-template-columns: 240px 1fr; min-height: 600px; background: var(--lbwo-bg); border-radius: var(--lbwo-radius); overflow: hidden; border: 1px solid var(--lbwo-border); box-shadow: var(--lbwo-shadow); }
.lbwo-dashboard__nav { background: var(--lbwo-white); border-right: 1px solid var(--lbwo-border); display: flex; flex-direction: column; padding: 20px 0; }
.lbwo-dashboard__brand { display: flex; align-items: center; gap: 10px; padding: 0 16px 16px; border-bottom: 1px solid var(--lbwo-border); margin-bottom: 12px; }
.lbwo-dashboard__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.lbwo-dashboard__avatar--placeholder { background: var(--lbwo-green-light); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; }
.lbwo-dashboard__brand strong { display: block; font-size: .9rem; line-height: 1.3; }
.lbwo-dashboard__menu { list-style: none; padding: 0; margin: 0; flex: 1; }
.lbwo-dashboard__menu-item { display: flex; align-items: center; gap: 10px; padding: 10px 20px; font-size: .88rem; font-weight: 500; color: var(--lbwo-text); text-decoration: none; transition: background var(--lbwo-transition), color var(--lbwo-transition); position: relative; }
.lbwo-dashboard__menu-item:hover { background: var(--lbwo-bg); color: var(--lbwo-green); }
.lbwo-dashboard__menu-item.is-active { background: var(--lbwo-green-light); color: var(--lbwo-green-dark); font-weight: 700; border-right: 3px solid var(--lbwo-green); }
.lbwo-dashboard__menu-icon { font-size: 1.1rem; }
.lbwo-badge-count { margin-left: auto; background: var(--lbwo-danger); color: #fff; font-size: .7rem; font-weight: 700; min-width: 18px; height: 18px; border-radius: 999px; display: flex; align-items: center; justify-content: center; padding: 0 4px; }
.lbwo-dashboard__footer-links { padding: 16px 20px 0; border-top: 1px solid var(--lbwo-border); display: flex; flex-direction: column; gap: 8px; }
.lbwo-dashboard__footer-links a { font-size: .82rem; color: var(--lbwo-muted); text-decoration: none; }
.lbwo-dashboard__footer-links a:hover { color: var(--lbwo-green); }
.lbwo-dashboard__content { padding: 24px; overflow-y: auto; }
.lbwo-tab-title { font-size: 1.3rem; font-weight: 800; margin: 0 0 20px; }
.lbwo-tab-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; flex-wrap: wrap; gap: 12px; }

/* Stats */
.lbwo-stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 16px; margin-bottom: 28px; }
.lbwo-stat-card { background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius); padding: 20px; text-align: center; box-shadow: var(--lbwo-shadow); }
.lbwo-stat-card--highlight { border-color: var(--lbwo-green); background: var(--lbwo-green-light); }
.lbwo-stat-card__icon { font-size: 1.8rem; display: block; margin-bottom: 6px; }
.lbwo-stat-card__value { font-size: 1.8rem; font-weight: 800; color: var(--lbwo-green-dark); }
.lbwo-stat-card__label { font-size: .8rem; color: var(--lbwo-muted); font-weight: 600; margin-top: 4px; }

/* Quick actions */
.lbwo-quick-actions { margin-bottom: 28px; }
.lbwo-quick-actions h3 { font-size: .9rem; color: var(--lbwo-muted); font-weight: 600; margin: 0 0 10px; text-transform: uppercase; letter-spacing: .05em; }
.lbwo-quick-actions__grid { display: flex; gap: 10px; flex-wrap: wrap; }
.lbwo-quick-action-btn { background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius-sm); padding: 10px 16px; font-size: .88rem; font-weight: 600; color: var(--lbwo-text); text-decoration: none; transition: border-color var(--lbwo-transition), color var(--lbwo-transition); }
.lbwo-quick-action-btn:hover { border-color: var(--lbwo-green); color: var(--lbwo-green); }
.lbwo-recent-orders h3 { font-size: 1rem; font-weight: 700; margin-bottom: 12px; }

/* Product list */
.lbwo-product-list { display: flex; flex-direction: column; gap: 10px; margin-top: 16px; }
.lbwo-product-row { display: flex; align-items: center; gap: 12px; background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius-sm); padding: 10px 14px; }
.lbwo-product-row__img { width: 50px; height: 50px; border-radius: var(--lbwo-radius-sm); object-fit: cover; flex-shrink: 0; }
.lbwo-product-row__img--placeholder { background: var(--lbwo-bg); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; border: 1px dashed var(--lbwo-border); }
.lbwo-product-row__info { flex: 1; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.lbwo-product-row__price { font-weight: 700; color: var(--lbwo-green-dark); margin-left: auto; }
.lbwo-product-row__actions { display: flex; gap: 6px; flex-shrink: 0; }

.lbwo-card { background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius); padding: 20px; margin-bottom: 20px; box-shadow: var(--lbwo-shadow); }
.lbwo-hint { font-size: .82rem; color: var(--lbwo-muted); margin: 4px 0; }

/* Badge cards */
.lbwo-badge-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; margin-bottom: 20px; }
.lbwo-badge-card { background: var(--lbwo-white); border: 2px solid var(--lbwo-border); border-radius: var(--lbwo-radius); padding: 24px 16px; text-align: center; transition: border-color var(--lbwo-transition), box-shadow var(--lbwo-transition); }
.lbwo-badge-card--active { border-color: var(--lbwo-green); background: var(--lbwo-green-light); }
.lbwo-badge-card__icon { font-size: 2.5rem; display: block; margin-bottom: 8px; }
.lbwo-badge-card__name { font-size: .95rem; font-weight: 700; margin: 0 0 12px; }
.lbwo-badge-card__status { display: inline-block; padding: 4px 10px; border-radius: 999px; font-size: .78rem; font-weight: 600; }
.lbwo-badge-card__status--active  { background: #d1fae5; color: #065f46; }
.lbwo-badge-card__status--pending { background: #fef3c7; color: #92400e; }

/* Chat */
.lbwo-chat { display: flex; flex-direction: column; height: 480px; border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius); overflow: hidden; background: var(--lbwo-bg); }
.lbwo-chat__messages { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.lbwo-chat__empty { text-align: center; color: var(--lbwo-muted); padding: 24px; font-size: .9rem; }
.lbwo-chat__bubble { max-width: 75%; }
.lbwo-chat__bubble--self { align-self: flex-end; }
.lbwo-chat__bubble--other { align-self: flex-start; }
.lbwo-chat__bubble-text { padding: 10px 14px; border-radius: 12px; font-size: .9rem; line-height: 1.5; word-break: break-word; }
.lbwo-chat__bubble--self  .lbwo-chat__bubble-text { background: var(--lbwo-green); color: #fff; border-bottom-right-radius: 4px; }
.lbwo-chat__bubble--other .lbwo-chat__bubble-text { background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-bottom-left-radius: 4px; }
.lbwo-chat__bubble-meta { font-size: .72rem; color: var(--lbwo-muted); margin-top: 4px; }
.lbwo-chat__bubble--self .lbwo-chat__bubble-meta { text-align: right; }
.lbwo-chat__input-bar { display: flex; border-top: 1px solid var(--lbwo-border); background: var(--lbwo-white); }
.lbwo-chat__textarea { flex: 1; border: none; outline: none; padding: 14px 16px; font-family: var(--lbwo-font); font-size: .9rem; resize: none; max-height: 100px; }
.lbwo-chat__send { border-radius: 0; padding: 14px 20px; font-size: 1.1rem; }
