/* =============================================
   GOBOT LICENCE - Frontend Styles (Light Theme)
   Dashboard & Support Panel
   ============================================= */

:root {
  --gbd-bg:        #f8f9fb;
  --gbd-surface:   #ffffff;
  --gbd-surface2:  #f1f4f9;
  --gbd-border:    #e2e7ef;
  --gbd-border2:   #d0d7e3;
  --gbd-text:      #1a2035;
  --gbd-text2:     #4b5568;
  --gbd-muted:     #8a96a8;
  --gbd-primary:   #3b6ff0;
  --gbd-primary-s: #e8effe;
  --gbd-success:   #16a34a;
  --gbd-success-s: #dcfce7;
  --gbd-warn:      #d97706;
  --gbd-warn-s:    #fef3c7;
  --gbd-danger:    #dc2626;
  --gbd-danger-s:  #fee2e2;
  --gbd-info:      #0284c7;
  --gbd-info-s:    #e0f2fe;
  --gbd-radius:    10px;
  --gbd-shadow:    0 1px 4px rgba(0,0,0,.07), 0 4px 16px rgba(0,0,0,.06);
  --gbd-shadow-lg: 0 8px 32px rgba(0,0,0,.12);
}

/* ── Base ────────────────────────────────────── */
.gbd-wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 16px 60px;
  color: var(--gbd-text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--gbd-bg);
}
.gbd-wrap * { box-sizing: border-box; }

/* ── Header ──────────────────────────────────── */
.gbd-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 28px 0 22px;
  border-bottom: 1px solid var(--gbd-border);
  margin-bottom: 26px;
  gap: 12px;
  flex-wrap: wrap;
}
.gbd-header-left  { display: flex; align-items: center; gap: 14px; }
.gbd-avatar       { border-radius: 50%; border: 2px solid var(--gbd-border); }
.gbd-greeting     { font-size: 18px; font-weight: 700; color: var(--gbd-text); }
.gbd-email        { font-size: 13px; color: var(--gbd-muted); margin-top: 2px; }

/* ── Stats ───────────────────────────────────── */
.gbd-stats {
  display: flex;
  gap: 12px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}
.gbd-stat {
  background: var(--gbd-surface);
  border: 1px solid var(--gbd-border);
  border-radius: var(--gbd-radius);
  padding: 16px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 100px;
  box-shadow: var(--gbd-shadow);
}
.gbd-stat-active { border-top: 3px solid var(--gbd-success); }
.gbd-stat-warn   { border-top: 3px solid var(--gbd-warn); }
.gbd-stat-num    { font-size: 28px; font-weight: 800; line-height: 1; color: var(--gbd-text); }
.gbd-stat-label  { font-size: 11px; color: var(--gbd-muted); margin-top: 5px;
                   text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }

/* ── Section title ───────────────────────────── */
.gbd-section-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--gbd-muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 14px;
}

/* ── Licence cards ───────────────────────────── */
.gbd-licence-list { display: flex; flex-direction: column; gap: 14px; }

.gbd-licence-card {
  background: var(--gbd-surface);
  border: 1px solid var(--gbd-border);
  border-radius: var(--gbd-radius);
  padding: 20px 22px;
  box-shadow: var(--gbd-shadow);
  transition: box-shadow .2s, border-color .2s;
}
.gbd-licence-card:hover    { box-shadow: var(--gbd-shadow-lg); border-color: var(--gbd-border2); }
.gbd-card-active           { border-left: 3px solid var(--gbd-success); }
.gbd-card-expired          { border-left: 3px solid var(--gbd-danger); opacity: .85; }
.gbd-card-suspended        { border-left: 3px solid var(--gbd-warn); }
.gbd-card-inactive         { border-left: 3px solid var(--gbd-muted); opacity: .75; }

.gbd-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

/* Key */
.gbd-key-row  { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.gbd-key {
  font-family: 'SFMono-Regular', 'Consolas', monospace;
  font-size: 14px;
  font-weight: 700;
  color: var(--gbd-info);
  background: var(--gbd-info-s);
  padding: 5px 11px;
  border-radius: 6px;
  letter-spacing: .04em;
  border: 1px solid #bae6fd;
}
.gbd-copy-btn {
  background: none; border: none; cursor: pointer;
  font-size: 14px; padding: 4px 6px; opacity: .5;
  border-radius: 5px; transition: opacity .15s, background .15s;
}
.gbd-copy-btn:hover { opacity: 1; background: var(--gbd-surface2); }
.gbd-copy-toast { font-size: 12px; color: var(--gbd-success); font-weight: 600; }

/* Badges */
.gbd-badges { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.gbd-badge {
  font-size: 11px; font-weight: 700;
  padding: 3px 9px; border-radius: 20px;
  text-transform: uppercase; letter-spacing: .04em;
}
.gbd-plan-1month, .gbd-plan-3months { background: var(--gbd-primary-s); color: var(--gbd-primary); }
.gbd-plan-6months, .gbd-plan-1year  { background: #f3e8ff; color: #7c3aed; }
.gbd-plan-lifetime                   { background: var(--gbd-success-s); color: var(--gbd-success); }
.gbd-plan-basic                      { background: var(--gbd-surface2); color: var(--gbd-muted); }

.gbd-status-active    { background: var(--gbd-success-s); color: var(--gbd-success); }
.gbd-status-expired   { background: var(--gbd-danger-s);  color: var(--gbd-danger); }
.gbd-status-suspended { background: var(--gbd-warn-s);    color: var(--gbd-warn); }
.gbd-status-inactive  { background: var(--gbd-surface2);  color: var(--gbd-muted); }

/* Info row */
.gbd-card-info {
  display: flex;
  gap: 28px;
  margin-bottom: 18px;
  flex-wrap: wrap;
  padding: 14px 16px;
  background: var(--gbd-surface2);
  border-radius: 8px;
}
.gbd-info-item  { display: flex; flex-direction: column; gap: 4px; }
.gbd-info-label { font-size: 11px; color: var(--gbd-muted); text-transform: uppercase;
                  letter-spacing: .04em; font-weight: 600; }
.gbd-info-val   { font-size: 14px; color: var(--gbd-text); display: flex; align-items: center; gap: 8px; font-weight: 500; }

.gbd-forever  { color: var(--gbd-success); }
.gbd-expired  { color: var(--gbd-danger); }
.gbd-expiring { color: var(--gbd-warn); }

.gbd-act-bar  { display: inline-block; width: 60px; height: 5px;
                background: var(--gbd-border); border-radius: 3px; overflow: hidden; }
.gbd-act-fill { display: block; height: 100%; border-radius: 3px; transition: width .3s; }

/* Card actions */
.gbd-card-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* ── Buttons ─────────────────────────────────── */
.gbd-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 8px 16px; border-radius: 8px; border: none;
  font-size: 13px; font-weight: 600; cursor: pointer;
  text-decoration: none; transition: all .15s;
  line-height: 1.4; white-space: nowrap;
}
.gbd-btn:hover  { opacity: .88; text-decoration: none; transform: translateY(-1px); }
.gbd-btn:active { transform: translateY(0) scale(.98); }

.gbd-btn-primary   { background: var(--gbd-primary); color: #fff; box-shadow: 0 2px 6px rgba(59,111,240,.3); }
.gbd-btn-success   { background: var(--gbd-success); color: #fff; }
.gbd-btn-warn      { background: var(--gbd-warn);    color: #fff; }
.gbd-btn-danger    { background: var(--gbd-danger);  color: #fff; }
.gbd-btn-secondary { background: var(--gbd-surface); border: 1px solid var(--gbd-border2);
                     color: var(--gbd-text2); box-shadow: var(--gbd-shadow); }
.gbd-btn-ghost     { background: transparent; border: 1px solid var(--gbd-border2); color: var(--gbd-muted); }
.gbd-btn-ghost:hover { color: var(--gbd-text); border-color: var(--gbd-text); }

/* ── Empty state ─────────────────────────────── */
.gbd-empty {
  text-align: center; padding: 60px 20px;
  background: var(--gbd-surface); border-radius: var(--gbd-radius);
  border: 1px dashed var(--gbd-border2); color: var(--gbd-muted);
  box-shadow: var(--gbd-shadow);
}
.gbd-empty-icon { font-size: 40px; margin-bottom: 14px; }
.gbd-empty p    { margin-bottom: 18px; font-size: 15px; color: var(--gbd-text2); }

/* ── Login / access notice ───────────────────── */
.gbd-login-notice {
  text-align: center; padding: 60px 20px;
  background: var(--gbd-surface); border-radius: var(--gbd-radius);
  border: 1px solid var(--gbd-border); color: var(--gbd-muted);
  box-shadow: var(--gbd-shadow);
}
.gbd-login-icon     { font-size: 40px; margin-bottom: 14px; }
.gbd-login-notice a { color: var(--gbd-primary); }

/* ── Modal ───────────────────────────────────── */
.gbd-modal {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(15,20,40,.45); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.gbd-modal-box {
  background: var(--gbd-surface); border: 1px solid var(--gbd-border);
  border-radius: 14px; width: 100%; max-width: 560px;
  max-height: 80vh; display: flex; flex-direction: column;
  box-shadow: var(--gbd-shadow-lg);
}
.gbd-modal-wide { max-width: 760px; }
.gbd-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px; border-bottom: 1px solid var(--gbd-border);
}
.gbd-modal-head h3  { margin: 0; font-size: 16px; font-weight: 700; color: var(--gbd-text); }
.gbd-modal-close {
  background: var(--gbd-surface2); border: none; cursor: pointer;
  font-size: 14px; color: var(--gbd-muted); padding: 5px 9px;
  border-radius: 7px; transition: background .15s, color .15s; line-height: 1;
}
.gbd-modal-close:hover { background: var(--gbd-danger-s); color: var(--gbd-danger); }
.gbd-modal-body { padding: 18px 22px; overflow-y: auto; flex: 1; }

/* ── Table ───────────────────────────────────── */
.gbd-table-wrap { overflow-x: auto; border-radius: var(--gbd-radius); border: 1px solid var(--gbd-border); }
.gbd-table {
  width: 100%; border-collapse: collapse; font-size: 13px; color: var(--gbd-text);
}
.gbd-table th {
  text-align: left; padding: 11px 14px;
  font-size: 11px; font-weight: 700; color: var(--gbd-muted);
  text-transform: uppercase; letter-spacing: .05em;
  background: var(--gbd-surface2);
  border-bottom: 1px solid var(--gbd-border);
  white-space: nowrap;
}
.gbd-table td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--gbd-border);
  vertical-align: middle;
}
.gbd-table tr:last-child td { border-bottom: none; }
.gbd-table tr:hover td      { background: var(--gbd-primary-s); }

/* ── Machine item ────────────────────────────── */
.gbd-machine-item {
  background: var(--gbd-surface2); border: 1px solid var(--gbd-border);
  border-radius: 8px; padding: 12px 14px; margin-bottom: 8px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  flex-wrap: wrap;
}
.gbd-machine-info { flex: 1; }
.gbd-machine-id   { font-family: monospace; font-size: 12px; color: var(--gbd-info); font-weight: 700; }
.gbd-machine-meta { font-size: 12px; color: var(--gbd-muted); margin-top: 3px; }

/* ── Loading ─────────────────────────────────── */
.gbd-loading { text-align: center; padding: 30px; color: var(--gbd-muted); font-size: 14px; }

/* ── Support: header ─────────────────────────── */
.gbd-support-title { font-size: 22px; font-weight: 800; color: var(--gbd-text); margin: 0 0 4px; }
.gbd-support-sub   { font-size: 14px; color: var(--gbd-muted); margin: 0; }

/* ── Support: search ─────────────────────────── */
.gbd-search-box {
  display: flex; gap: 10px; margin-bottom: 24px; flex-wrap: wrap;
}
.gbd-search-input {
  flex: 1; min-width: 200px;
  background: var(--gbd-surface); border: 1px solid var(--gbd-border2);
  border-radius: 9px; padding: 11px 16px;
  color: var(--gbd-text); font-size: 14px; outline: none;
  transition: border-color .2s, box-shadow .2s;
  box-shadow: var(--gbd-shadow);
}
.gbd-search-input:focus { border-color: var(--gbd-primary); box-shadow: 0 0 0 3px rgba(59,111,240,.12); }
.gbd-search-input::placeholder { color: var(--gbd-muted); }

/* ── Drawer ──────────────────────────────────── */
.gbd-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 100%; max-width: 560px; z-index: 99998;
  background: var(--gbd-surface); border-left: 1px solid var(--gbd-border);
  box-shadow: var(--gbd-shadow-lg); overflow-y: auto;
  animation: gbd-slide-in .22s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
}
@keyframes gbd-slide-in {
  from { transform: translateX(100%); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}
.gbd-drawer-overlay {
  position: fixed; inset: 0; z-index: 99997;
  background: rgba(15,20,40,.35); backdrop-filter: blur(2px);
}
.gbd-drawer-inner  { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.gbd-drawer-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 20px 22px 16px; border-bottom: 1px solid var(--gbd-border);
  flex-shrink: 0;
}
.gbd-drawer-key { font-family: monospace; font-size: 13px; color: var(--gbd-info);
                  font-weight: 700; margin-bottom: 4px; }
.gbd-drawer-sub { font-size: 13px; color: var(--gbd-muted); }

/* Tabs */
.gbd-tabs {
  display: flex; border-bottom: 1px solid var(--gbd-border);
  padding: 0 22px; flex-shrink: 0; background: var(--gbd-surface);
}
.gbd-tab {
  background: none; border: none; cursor: pointer;
  padding: 12px 14px; font-size: 13px; font-weight: 600;
  color: var(--gbd-muted); border-bottom: 2px solid transparent;
  margin-bottom: -1px; transition: color .15s, border-color .15s;
}
.gbd-tab.active  { color: var(--gbd-primary); border-bottom-color: var(--gbd-primary); }
.gbd-tab:hover   { color: var(--gbd-text); }

.gbd-tab-content { padding: 18px 22px; flex: 1; overflow-y: auto; }
.gbd-tab-content:not(.active) { display: none; }

/* Action groups */
.gbd-action-group   { display: flex; flex-direction: column; gap: 22px; }
.gbd-action-label   { font-size: 12px; font-weight: 700; color: var(--gbd-muted);
                      text-transform: uppercase; letter-spacing: .05em; margin-bottom: 10px; }
.gbd-action-row     { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.gbd-extend-custom  { display: flex; gap: 6px; align-items: center; }
.gbd-input-small {
  width: 90px; background: var(--gbd-surface); border: 1px solid var(--gbd-border2);
  border-radius: 7px; padding: 7px 10px; color: var(--gbd-text);
  font-size: 13px; outline: none; transition: border-color .2s;
}
.gbd-input-small:focus { border-color: var(--gbd-primary); }

/* Feedback */
.gbd-feedback {
  margin-top: 16px; padding: 10px 14px; border-radius: 8px;
  font-size: 13px; font-weight: 600;
}
.gbd-feedback.success { background: var(--gbd-success-s); color: var(--gbd-success); border: 1px solid #bbf7d0; }
.gbd-feedback.error   { background: var(--gbd-danger-s);  color: var(--gbd-danger);  border: 1px solid #fecaca; }

/* ════════════════════════════════════════════════
   CHAT
   ════════════════════════════════════════════════ */

/* Chat tab panel */
#gbd-tab-chat { display: flex; flex-direction: column; padding: 0; flex: 1; min-height: 0; overflow: hidden; }

/* Messages area */
.gbd-chat-messages {
  flex: 1; overflow-y: auto; padding: 18px 22px;
  display: flex; flex-direction: column; gap: 12px;
  background: var(--gbd-bg);
  min-height: 300px; max-height: 420px;
}

/* Single message bubble */
.gbd-msg {
  display: flex; gap: 10px; align-items: flex-end; max-width: 80%;
}
.gbd-msg-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--gbd-surface2); border: 1px solid var(--gbd-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.gbd-msg-body { display: flex; flex-direction: column; gap: 3px; }
.gbd-msg-bubble {
  padding: 10px 14px; border-radius: 14px;
  font-size: 14px; line-height: 1.55; color: var(--gbd-text);
  background: var(--gbd-surface); border: 1px solid var(--gbd-border);
  box-shadow: var(--gbd-shadow); word-break: break-word;
}
.gbd-msg-meta {
  font-size: 11px; color: var(--gbd-muted); padding: 0 4px;
}

/* User message (right side) */
.gbd-msg-user { margin-left: auto; flex-direction: row-reverse; }
.gbd-msg-user .gbd-msg-bubble {
  background: var(--gbd-primary); color: #fff;
  border-color: var(--gbd-primary);
  border-radius: 14px 14px 4px 14px;
}
.gbd-msg-user .gbd-msg-meta { text-align: right; }
.gbd-msg-user .gbd-msg-avatar { background: var(--gbd-primary-s); }

/* Admin message (left side) */
.gbd-msg-admin .gbd-msg-bubble { border-radius: 14px 14px 14px 4px; }
.gbd-msg-admin .gbd-msg-avatar { background: #fef3c7; }

/* Typing indicator */
.gbd-typing { display: flex; gap: 4px; padding: 12px 14px; align-items: center; }
.gbd-typing span {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gbd-muted); animation: gbd-bounce .9s infinite;
}
.gbd-typing span:nth-child(2) { animation-delay: .15s; }
.gbd-typing span:nth-child(3) { animation-delay: .3s; }
@keyframes gbd-bounce {
  0%, 60%, 100% { transform: translateY(0); }
  30%           { transform: translateY(-5px); }
}

/* No messages */
.gbd-chat-empty {
  text-align: center; padding: 40px 20px; color: var(--gbd-muted); font-size: 14px;
}
.gbd-chat-empty-icon { font-size: 32px; margin-bottom: 10px; }

/* Input bar */
.gbd-chat-bar {
  padding: 14px 18px; border-top: 1px solid var(--gbd-border);
  display: flex; gap: 8px; align-items: flex-end;
  background: var(--gbd-surface); flex-shrink: 0;
}
.gbd-chat-input {
  flex: 1; background: var(--gbd-surface2); border: 1px solid var(--gbd-border2);
  border-radius: 10px; padding: 10px 14px;
  font-size: 14px; color: var(--gbd-text); outline: none; resize: none;
  max-height: 100px; min-height: 42px; line-height: 1.5;
  transition: border-color .2s, box-shadow .2s;
  font-family: inherit;
}
.gbd-chat-input:focus { border-color: var(--gbd-primary); box-shadow: 0 0 0 3px rgba(59,111,240,.1); }
.gbd-chat-input::placeholder { color: var(--gbd-muted); }
.gbd-chat-send {
  background: var(--gbd-primary); color: #fff; border: none;
  border-radius: 10px; padding: 10px 16px; cursor: pointer;
  font-size: 16px; flex-shrink: 0; transition: opacity .15s, transform .1s;
  box-shadow: 0 2px 6px rgba(59,111,240,.3);
}
.gbd-chat-send:hover  { opacity: .88; transform: translateY(-1px); }
.gbd-chat-send:active { transform: scale(.96); }
.gbd-chat-send:disabled { opacity: .5; cursor: not-allowed; transform: none; }

/* Conversation list in support panel */
.gbd-conv-list { display: flex; flex-direction: column; gap: 0; }
.gbd-conv-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border-bottom: 1px solid var(--gbd-border);
  cursor: pointer; transition: background .15s;
}
.gbd-conv-item:hover        { background: var(--gbd-surface2); }
.gbd-conv-item.active       { background: var(--gbd-primary-s); }
.gbd-conv-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--gbd-surface2); border: 1px solid var(--gbd-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
}
.gbd-conv-info   { flex: 1; min-width: 0; }
.gbd-conv-name   { font-size: 14px; font-weight: 600; color: var(--gbd-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gbd-conv-preview { font-size: 12px; color: var(--gbd-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
.gbd-conv-time   { font-size: 11px; color: var(--gbd-muted); flex-shrink: 0; }
.gbd-conv-unread {
  background: var(--gbd-primary); color: #fff;
  border-radius: 12px; font-size: 11px; font-weight: 700;
  padding: 2px 7px; flex-shrink: 0; min-width: 20px; text-align: center;
}

/* Support chat layout: list + chat side by side */
.gbd-support-chat-wrap {
  display: flex; gap: 0; border: 1px solid var(--gbd-border);
  border-radius: var(--gbd-radius); overflow: hidden;
  background: var(--gbd-surface); box-shadow: var(--gbd-shadow);
  height: 540px;
}
.gbd-support-conv-sidebar {
  width: 260px; flex-shrink: 0; border-right: 1px solid var(--gbd-border);
  display: flex; flex-direction: column; overflow: hidden;
}
.gbd-support-conv-sidebar-head {
  padding: 14px 16px; border-bottom: 1px solid var(--gbd-border);
  font-size: 13px; font-weight: 700; color: var(--gbd-muted);
  text-transform: uppercase; letter-spacing: .05em;
  background: var(--gbd-surface2);
}
.gbd-support-conv-list { flex: 1; overflow-y: auto; }
.gbd-support-chat-main {
  flex: 1; display: flex; flex-direction: column; min-width: 0;
}
.gbd-support-chat-main .gbd-chat-messages { max-height: none; flex: 1; }
.gbd-chat-select-hint {
  flex: 1; display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 10px; color: var(--gbd-muted); font-size: 14px;
  background: var(--gbd-bg);
}
.gbd-chat-select-hint-icon { font-size: 36px; }

/* ── Responsive ──────────────────────────────── */
@media (max-width: 640px) {
  .gbd-card-info  { flex-direction: column; gap: 12px; }
  .gbd-header     { flex-direction: column; align-items: flex-start; }
  .gbd-drawer     { max-width: 100%; }
  .gbd-stats      { gap: 8px; }
  .gbd-stat       { min-width: 80px; padding: 12px 16px; }
  .gbd-stat-num   { font-size: 22px; }
  .gbd-support-chat-wrap { flex-direction: column; height: auto; }
  .gbd-support-conv-sidebar { width: 100%; border-right: none; border-bottom: 1px solid var(--gbd-border); max-height: 200px; }
}

/* ════════════════════════════════════════════════
   ORDER FORM
   ════════════════════════════════════════════════ */

/* Steps indicator */
.gord-steps {
  display: flex; align-items: center; margin-bottom: 32px; flex-wrap: wrap; gap: 4px;
}
.gord-step {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--gbd-muted);
  padding: 7px 14px; border-radius: 20px;
  transition: all .2s;
}
.gord-step span {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--gbd-border); color: var(--gbd-muted);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; flex-shrink: 0;
}
.gord-step.active       { color: var(--gbd-primary); }
.gord-step.active span  { background: var(--gbd-primary); color: #fff; }
.gord-step.done         { color: var(--gbd-success); }
.gord-step.done span    { background: var(--gbd-success); color: #fff; }
.gord-step-line         { flex: 1; height: 1px; background: var(--gbd-border); min-width: 12px; }

/* Panel */
.gord-panel { animation: gord-fade .2s ease; }
@keyframes gord-fade { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }

.gord-panel-header {
  display: flex; align-items: center; gap: 16px; margin-bottom: 22px;
}
.gord-back-btn {
  background: none; border: none; cursor: pointer; font-size: 13px;
  color: var(--gbd-muted); padding: 5px 0; font-weight: 600;
  transition: color .15s;
}
.gord-back-btn:hover { color: var(--gbd-primary); }

/* Plan grid */
.gord-plan-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 14px; margin-bottom: 8px;
}
.gord-plan-card {
  background: var(--gbd-surface); border: 2px solid var(--gbd-border);
  border-radius: 14px; padding: 22px 16px 18px; text-align: center;
  position: relative; cursor: pointer; transition: all .2s;
  box-shadow: var(--gbd-shadow);
}
.gord-plan-card:hover          { border-color: var(--gbd-primary); box-shadow: var(--gbd-shadow-lg); transform: translateY(-2px); }
.gord-plan-card.gord-popular   { border-color: var(--gbd-primary); }
.gord-badge-popular {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  background: var(--gbd-primary); color: #fff;
  font-size: 11px; font-weight: 700; padding: 3px 12px; border-radius: 20px;
  white-space: nowrap;
}
.gord-plan-name  { font-size: 14px; font-weight: 700; color: var(--gbd-text); margin-bottom: 10px; }
.gord-plan-price { font-size: 24px; font-weight: 800; color: var(--gbd-primary); line-height: 1; }
.gord-plan-price span { font-size: 14px; font-weight: 600; }
.gord-plan-usd   { font-size: 12px; color: var(--gbd-muted); margin: 4px 0 14px; }
.gord-plan-features {
  list-style: none; padding: 0; margin: 0 0 16px;
  font-size: 12px; color: var(--gbd-text2); text-align: left; line-height: 2;
}
.gord-select-plan { width: 100%; justify-content: center; }

/* Selected plan label */
.gord-selected-plan {
  background: var(--gbd-primary-s); border: 1px solid #bfdbfe;
  border-radius: 9px; padding: 12px 16px; margin-bottom: 22px;
  font-size: 14px; font-weight: 600; color: var(--gbd-primary);
  display: flex; align-items: center; gap: 8px;
}

/* Form fields */
.gord-form   { display: flex; flex-direction: column; gap: 18px; }
.gord-field  { display: flex; flex-direction: column; gap: 6px; }
.gord-label  { font-size: 13px; font-weight: 700; color: var(--gbd-text2); }
.gord-req    { color: var(--gbd-danger); }
.gord-hint   { font-size: 12px; color: var(--gbd-muted); }
.gord-input {
  background: var(--gbd-surface); border: 1px solid var(--gbd-border2);
  border-radius: 9px; padding: 11px 14px; font-size: 14px; color: var(--gbd-text);
  outline: none; transition: border-color .2s, box-shadow .2s; width: 100%;
  font-family: inherit;
}
.gord-input:focus { border-color: var(--gbd-primary); box-shadow: 0 0 0 3px rgba(59,111,240,.1); }

/* Payment method selector */
.gord-method-row  { display: flex; gap: 12px; flex-wrap: wrap; }
.gord-method-card {
  display: flex; align-items: center; gap: 10px;
  border: 2px solid var(--gbd-border); border-radius: 10px;
  padding: 12px 18px; cursor: pointer; transition: all .15s;
  flex: 1; min-width: 140px; background: var(--gbd-surface);
}
.gord-method-card:hover              { border-color: var(--gbd-primary); }
.gord-method-card input[type=radio]  { display: none; }
.gord-method-card.selected           { border-color: var(--gbd-primary); background: var(--gbd-primary-s); }
.gord-method-icon  { font-size: 20px; }
.gord-method-label { font-size: 13px; font-weight: 600; color: var(--gbd-text); }

/* Payment info box */
.gord-pay-box {
  background: var(--gbd-surface2); border: 1px solid var(--gbd-border);
  border-radius: 12px; padding: 18px 20px; margin-bottom: 6px;
}
.gord-pay-title { font-size: 14px; font-weight: 700; color: var(--gbd-text); margin-bottom: 10px; }
.gord-pay-info  {
  font-family: monospace; font-size: 13px; color: var(--gbd-text2);
  background: var(--gbd-surface); border: 1px solid var(--gbd-border);
  border-radius: 8px; padding: 12px 14px; margin: 0 0 10px;
  white-space: pre-wrap; line-height: 1.8;
}
.gord-pay-amount { font-size: 14px; color: var(--gbd-text2); }
.gord-pay-amount strong { color: var(--gbd-danger); font-size: 18px; }

/* Upload area */
.gord-upload-area {
  border: 2px dashed var(--gbd-border2); border-radius: 12px;
  background: var(--gbd-surface2); transition: border-color .2s, background .2s;
  overflow: hidden; position: relative;
}
.gord-upload-area:hover, .gord-upload-area.drag-over {
  border-color: var(--gbd-primary); background: var(--gbd-primary-s);
}
.gord-upload-label {
  display: block; padding: 36px 20px; text-align: center;
  color: var(--gbd-muted); font-size: 14px; line-height: 1.8;
  cursor: pointer; width: 100%;
}
.gord-upload-label:hover { color: var(--gbd-primary); }
.gord-upload-icon    { font-size: 32px; margin-bottom: 8px; }
.gord-upload-hint    { font-size: 12px; color: var(--gbd-border2); margin-top: 4px; }
.gord-upload-preview { padding: 20px; text-align: center; }

/* Success box */
.gord-success-box {
  text-align: center; padding: 50px 30px;
  background: var(--gbd-surface); border-radius: 16px;
  border: 1px solid var(--gbd-border); box-shadow: var(--gbd-shadow);
}
.gord-success-icon { font-size: 56px; margin-bottom: 16px; }
.gord-success-box h3 { font-size: 22px; font-weight: 800; color: var(--gbd-text); margin: 0 0 14px; }
.gord-success-box p  { font-size: 15px; color: var(--gbd-text2); margin: 6px 0; line-height: 1.6; }

/* Orders table in support panel */
.gord-order-bill-thumb {
  width: 48px; height: 40px; object-fit: cover;
  border-radius: 6px; border: 1px solid var(--gbd-border);
  cursor: pointer; transition: transform .15s;
}
.gord-order-bill-thumb:hover { transform: scale(1.08); }

/* Bill lightbox */
.gord-lightbox {
  position: fixed; inset: 0; z-index: 999999;
  background: rgba(0,0,0,.8); display: flex; align-items: center; justify-content: center;
  padding: 20px; cursor: pointer;
}
.gord-lightbox img { max-width: 100%; max-height: 90vh; border-radius: 10px; }

/* Confirm/Reject modal */
.gord-action-modal {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(15,20,40,.45); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center; padding: 16px;
}
.gord-action-modal-box {
  background: var(--gbd-surface); border: 1px solid var(--gbd-border);
  border-radius: 14px; width: 100%; max-width: 440px;
  box-shadow: var(--gbd-shadow-lg); padding: 24px 26px;
}
.gord-action-modal-box h4 { margin: 0 0 14px; font-size: 16px; color: var(--gbd-text); }
.gord-note-input {
  width: 100%; background: var(--gbd-surface2); border: 1px solid var(--gbd-border2);
  border-radius: 8px; padding: 10px 12px; font-size: 13px; color: var(--gbd-text);
  outline: none; resize: vertical; min-height: 70px; font-family: inherit; margin-bottom: 14px;
}
.gord-note-input:focus { border-color: var(--gbd-primary); }
.gord-modal-actions { display: flex; gap: 8px; justify-content: flex-end; }

@media (max-width: 600px) {
  .gord-plan-grid { grid-template-columns: 1fr 1fr; }
  .gord-steps     { gap: 2px; }
  .gord-step      { padding: 6px 8px; font-size: 12px; }
}

/* ════════════════════════════════════════════════
   DASHBOARD TABS
   ════════════════════════════════════════════════ */

.gbd-dash-tabs {
  display: flex; gap: 0;
  border-bottom: 2px solid var(--gbd-border);
  margin-bottom: 24px;
}
.gbd-dash-tab {
  background: none; border: none; cursor: pointer;
  padding: 11px 18px; font-size: 14px; font-weight: 600;
  color: var(--gbd-muted); border-bottom: 2px solid transparent;
  margin-bottom: -2px; transition: color .15s, border-color .15s;
  display: flex; align-items: center; gap: 6px;
}
.gbd-dash-tab:hover  { color: var(--gbd-text); }
.gbd-dash-tab.active { color: var(--gbd-primary); border-bottom-color: var(--gbd-primary); }
.gbd-tab-badge {
  background: var(--gbd-danger); color: #fff;
  border-radius: 10px; font-size: 10px; font-weight: 700;
  padding: 1px 6px; min-width: 18px; text-align: center; line-height: 16px;
}

.gbd-dash-panel { animation: gbd-fade-in .18s ease; }
@keyframes gbd-fade-in { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:none; } }

/* ════════════════════════════════════════════════
   ORDER CARDS (user view)
   ════════════════════════════════════════════════ */

.gbd-order-list { display: flex; flex-direction: column; gap: 14px; }

.gbd-order-card {
  background: var(--gbd-surface); border: 1px solid var(--gbd-border);
  border-radius: var(--gbd-radius); overflow: hidden;
  box-shadow: var(--gbd-shadow); transition: box-shadow .2s;
}
.gbd-order-card:hover { box-shadow: var(--gbd-shadow-lg); }

.gbd-order-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; background: var(--gbd-surface2);
  border-bottom: 1px solid var(--gbd-border); gap: 12px; flex-wrap: wrap;
}
.gbd-order-ref  { font-family: monospace; font-size: 14px; font-weight: 700; color: var(--gbd-text); }
.gbd-order-date { font-size: 12px; color: var(--gbd-muted); margin-top: 2px; }

.gbd-order-body { padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }

.gbd-order-info-row {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  font-size: 13px;
}
.gbd-order-info-row .gbd-info-label {
  color: var(--gbd-muted); font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .04em; min-width: 110px;
}

.gbd-order-notice {
  margin-top: 6px; padding: 10px 14px; border-radius: 8px;
  font-size: 13px; color: var(--gbd-warn);
  background: var(--gbd-warn-s); border: 1px solid #fde68a; line-height: 1.5;
}
.gbd-order-notice-error {
  color: var(--gbd-danger); background: var(--gbd-danger-s); border-color: #fca5a5;
}

/* Status badge variants for orders */
.gbd-status-pending   { background: var(--gbd-warn-s);    color: var(--gbd-warn);    border: 1px solid #fde68a; }
.gbd-status-confirmed { background: var(--gbd-success-s); color: var(--gbd-success); border: 1px solid #bbf7d0; }
.gbd-status-rejected  { background: var(--gbd-danger-s);  color: var(--gbd-danger);  border: 1px solid #fca5a5; }

/* ════════════════════════════════════════════════
   CHAT PANEL (inside dashboard tab)
   ════════════════════════════════════════════════ */

.gbd-chat-panel-wrap {
  background: var(--gbd-surface); border: 1px solid var(--gbd-border);
  border-radius: var(--gbd-radius); overflow: hidden;
  box-shadow: var(--gbd-shadow); display: flex; flex-direction: column;
  height: 500px;
}
.gbd-chat-panel-head {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-bottom: 1px solid var(--gbd-border);
  background: var(--gbd-surface2); flex-shrink: 0;
}
.gbd-chat-online-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--gbd-success); flex-shrink: 0;
  box-shadow: 0 0 0 3px var(--gbd-success-s);
  animation: gbd-pulse 2s infinite;
}
@keyframes gbd-pulse {
  0%, 100% { box-shadow: 0 0 0 3px var(--gbd-success-s); }
  50%       { box-shadow: 0 0 0 5px var(--gbd-success-s); }
}
.gbd-chat-panel-title { font-size: 14px; font-weight: 700; color: var(--gbd-text); }
.gbd-chat-panel-sub   { font-size: 12px; color: var(--gbd-muted); margin-top: 2px; }
.gbd-chat-panel-wrap .gbd-chat-messages { flex: 1; max-height: none; }

/* ════════════════════════════════════════════════
   ORDER POPUP MODAL
   ════════════════════════════════════════════════ */

.gbd-order-popup {
  align-items: flex-start;
  padding: 16px;
  overflow-y: auto;
}
.gbd-modal-order-box {
  max-width: 820px;
  max-height: none;
  width: 100%;
  margin: 20px auto;
}
.gbd-order-popup-body {
  padding: 0;
  overflow: visible;
}
/* Ẩn header của order form khi trong popup (đã có modal header rồi) */
.gbd-order-popup-body .gbd-header { display: none; }
/* Remove outer wrap padding since modal already has padding */
.gbd-order-popup-body .gbd-wrap {
  padding: 16px 20px 24px;
  max-width: none;
  background: transparent;
}
/* Steps bên trong popup */
.gbd-order-popup-body .gord-steps { margin-top: 4px; }

/* ── Quantity selector ───────────────────────── */
.gord-qty-wrap    { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--gbd-border); }
.gord-qty-label   { font-size: 12px; font-weight: 700; color: var(--gbd-muted);
                    text-transform: uppercase; letter-spacing: .04em; margin-bottom: 8px; }
.gord-qty-row     { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 10px; }
.gord-qty-btn     {
  width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--gbd-border2);
  background: var(--gbd-surface); color: var(--gbd-text); font-size: 18px; font-weight: 700;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .15s; line-height: 1;
}
.gord-qty-btn:hover   { border-color: var(--gbd-primary); color: var(--gbd-primary); background: var(--gbd-primary-s); }
.gord-qty-val     { font-size: 24px; font-weight: 800; color: var(--gbd-text); min-width: 32px; text-align: center; }
.gord-qty-total   { font-size: 13px; color: var(--gbd-text2); text-align: center; margin-bottom: 4px; }
.gord-qty-total strong { color: var(--gbd-danger); font-size: 16px; }

/* ════════════════════════════════════════════════
   DOWNLOAD TAB
   ════════════════════════════════════════════════ */

.gbd-download-list { display: flex; flex-direction: column; gap: 12px; }

.gbd-download-item {
  display: flex; align-items: center; gap: 14px;
  background: var(--gbd-surface); border: 1px solid var(--gbd-border);
  border-radius: var(--gbd-radius); padding: 16px 18px;
  box-shadow: var(--gbd-shadow); transition: box-shadow .2s;
}
.gbd-download-item:hover { box-shadow: var(--gbd-shadow-lg); }

.gbd-download-icon {
  font-size: 28px; width: 48px; height: 48px; border-radius: 10px;
  background: var(--gbd-primary-s); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.gbd-download-info  { flex: 1; min-width: 0; }
.gbd-download-name  { font-size: 14px; font-weight: 700; color: var(--gbd-text); }
.gbd-download-note  { font-size: 12px; color: var(--gbd-muted); margin-top: 2px; }
.gbd-download-ver   {
  display: inline-block; font-size: 11px; font-weight: 700; color: var(--gbd-primary);
  background: var(--gbd-primary-s); padding: 1px 7px; border-radius: 10px; margin-top: 4px;
}
