/* ═══════════════════════════════════════════════
   MedMarket Platform — Component Styles v3.0
   Buttons · Cards · Forms · Modals · Badges · Tables
   ═══════════════════════════════════════════════ */

/* ── STAT CARDS ── */
.stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; margin-bottom:18px; }
.stat {
  background:var(--wh); border-radius:var(--radius-lg); padding:16px 18px;
  border:1px solid var(--gy2); box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; gap:4px;
  transition:var(--transition);
}
.stat:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
.stat-icon { font-size:24px; margin-bottom:4px; }
.stat-val { font-size:26px; font-weight:800; color:var(--gy6); line-height:1; letter-spacing:-.5px; }
.stat-label { font-size:11px; color:var(--gy4); font-weight:500; }
.stat.accent .stat-val { color:var(--or); }
.stat.success .stat-val { color:var(--gr); }
.stat.warning .stat-val { color:var(--am); }
.stat.danger  .stat-val { color:var(--rd); }

/* ── CARDS ── */
.card {
  background:var(--wh); border-radius:var(--radius-lg);
  border:1px solid var(--gy2); padding:16px 18px;
  box-shadow:var(--shadow-sm);
}
.card-title {
  font-size:14px; font-weight:700; color:var(--gy6); margin-bottom:12px;
  display:flex; align-items:center; justify-content:space-between;
}
.card-sm { padding:12px 14px; }

/* ── GEAR GRID ── */
.gear-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:14px; }

.gear-card {
  background:var(--wh); border-radius:var(--radius-lg); border:2px solid var(--gy2);
  overflow:hidden; transition:var(--transition);
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
  position:relative;
}
.gear-card:hover { border-color:var(--gy3); transform:translateY(-3px); box-shadow:var(--shadow); }
.gear-card.selected { border-color:var(--or); box-shadow:0 0 0 3px rgba(232,82,26,.13), var(--shadow); }
.gear-card.unavailable { opacity:.55; }

/* ── GEAR CARD CHECKBOX (always visible) ── */
.gear-cb {
  position:absolute; top:9px; left:9px; z-index:5;
  width:24px; height:24px; border-radius:7px;
  border:2px solid rgba(255,255,255,.9);
  background:rgba(0,0,0,.30);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--transition);
  font-size:13px; font-weight:800; color:#fff;
  box-shadow:0 1px 4px rgba(0,0,0,.25);
  backdrop-filter:blur(2px);
}
.gear-card:hover .gear-cb { border-color:#fff; background:rgba(0,0,0,.45); }
.gear-card.selected .gear-cb {
  background:var(--or); border-color:var(--or);
  box-shadow:0 2px 8px rgba(232,82,26,.5);
}

/* Available qty tag on gear card */
.gear-qty-tag {
  position:absolute; bottom:9px; left:9px; z-index:4;
  background:rgba(0,0,0,.55); color:#fff;
  font-size:10px; font-weight:700; padding:2px 8px;
  border-radius:999px; backdrop-filter:blur(4px);
  pointer-events:none;
}
.gear-thumb-img-wrap { cursor:pointer; }

.gear-thumb {
  height:148px; width:100%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden; cursor:pointer;
  background:linear-gradient(135deg,#f0f2f5 0%,#e8eaf0 100%);
}
.gear-thumb::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:40px;
  background:linear-gradient(to bottom,transparent,rgba(0,0,0,.18));
  pointer-events:none; z-index:1;
}
.gear-thumb-emoji { font-size:52px; z-index:1; filter:drop-shadow(0 2px 4px rgba(0,0,0,.08)); pointer-events:none; }
.gear-thumb-img { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; transition:transform .3s ease; }
.gear-card:hover .gear-thumb-img { transform:scale(1.04); }

.gear-status-dot {
  position:absolute; top:9px; right:9px; width:10px; height:10px;
  border-radius:50%; border:2px solid #fff; z-index:3;
  box-shadow:0 1px 4px rgba(0,0,0,.2);
}

.gear-body { padding:11px 13px; flex:1; display:flex; flex-direction:column; gap:5px; cursor:pointer; }
.gear-name {
  font-size:12.5px; font-weight:700; color:var(--gy6); line-height:1.35;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.gear-meta { font-size:10.5px; color:var(--gy4); display:flex; gap:5px; align-items:center; }
.gear-foot { display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:6px; }
.gear-note { font-size:10px; color:var(--gy4); overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }

/* Select-all toolbar */
.gear-sel-toolbar {
  display:flex; align-items:center; gap:8px; padding:8px 0;
  margin-bottom:8px; flex-wrap:wrap;
}
.gear-sel-info {
  font-size:12px; color:var(--gy5); font-weight:500; flex:1;
}
.gear-sel-info span { color:var(--or); font-weight:700; }

/* ── PROJECT GEAR STEP — qty stepper ── */
.proj-gear-sel-row {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; background:var(--or-pale);
  border:1.5px solid var(--or); border-radius:var(--radius-lg);
  margin-bottom:8px;
}
.proj-gear-sel-row .pgs-info { flex:1; }
.proj-gear-sel-row .pgs-name { font-size:12px; font-weight:700; color:var(--or-dk); }
.proj-gear-sel-row .pgs-max  { font-size:10px; color:var(--gy4); margin-top:1px; }
.qty-stepper {
  display:flex; align-items:center; gap:4px; flex-shrink:0;
}
.qty-stepper button {
  width:26px; height:26px; border-radius:7px;
  border:1.5px solid var(--or); background:#fff;
  color:var(--or); font-size:16px; font-weight:700;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:var(--transition); padding:0; line-height:1;
}
.qty-stepper button:hover { background:var(--or); color:#fff; }
.qty-stepper input {
  width:40px; text-align:center; border:1.5px solid var(--or);
  border-radius:7px; font-size:13px; font-weight:700; color:var(--or-dk);
  padding:3px 4px; font-family:inherit; outline:none; background:#fff;
}

/* ── BADGES ── */
.badge { display:inline-flex; align-items:center; padding:2px 9px; border-radius:999px; font-size:11px; font-weight:600; gap:4px; }
.b-or { background:var(--or-pale); color:var(--or-dk); }
.b-gr { background:var(--gr-lt); color:var(--gr-dk); }
.b-rd { background:var(--rd-lt); color:var(--rd-dk); }
.b-bl { background:var(--bl-lt); color:var(--bl-dk); }
.b-am { background:var(--am-lt); color:var(--am-dk); }
.b-pu { background:var(--pu-lt); color:var(--pu-dk); }
.b-tl { background:var(--tl-lt); color:var(--tl-dk); }
.b-gy { background:var(--gy1); color:var(--gy4); border:1px solid var(--gy2); }
.qty-badge {
  background:var(--gy1); color:var(--gy6); font-size:11px; font-weight:700;
  padding:2px 8px; border-radius:999px; border:1px solid var(--gy2);
}

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:var(--radius);
  border:1px solid var(--gy2); background:var(--wh);
  color:var(--gy6); font-size:13px; font-weight:600;
  cursor:pointer; transition:var(--transition);
  white-space:nowrap; font-family:inherit;
}
.btn:hover { background:var(--gy1); }
.btn:active { transform:scale(.97); }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none !important; }
.btn-primary  { background:var(--or); border-color:var(--or); color:#fff; }
.btn-primary:hover { background:var(--or-dk); border-color:var(--or-dk); }
.btn-dark     { background:var(--dk); border-color:var(--dk); color:#fff; }
.btn-dark:hover { background:var(--dk2); }
.btn-tg       { background:#229ED9; border-color:#229ED9; color:#fff; }
.btn-tg:hover  { background:#1a8bc4; }
.btn-success  { background:var(--gr); border-color:var(--gr); color:#fff; }
.btn-success:hover { background:var(--gr-dk); }
.btn-danger   { background:var(--rd-lt); border-color:var(--rd); color:var(--rd-dk); }
.btn-danger:hover  { background:var(--rd); color:#fff; }
.btn-warn     { background:var(--am-lt); border-color:var(--am); color:var(--am-dk); }
.btn-sm       { padding:5px 11px; font-size:12px; }
.btn-xs       { padding:3px 8px; font-size:11px; }
.btn-icon     { width:34px; height:34px; padding:0; justify-content:center; font-size:16px; }
.btn-full     { width:100%; justify-content:center; }
.btn-full-mobile { width:auto; }

/* ── FORMS ── */
.form-group { margin-bottom:14px; }
.form-label {
  font-size:11px; font-weight:700; color:var(--gy5);
  margin-bottom:5px; display:block;
  text-transform:uppercase; letter-spacing:.05em;
}
.form-input {
  width:100%; padding:10px 12px; border:1.5px solid var(--gy2);
  border-radius:var(--radius); font-size:13px; font-family:inherit;
  color:var(--gy6); background:var(--wh); outline:none;
  transition:border-color .15s, box-shadow .15s;
}
.form-input:focus { border-color:var(--or); box-shadow:0 0 0 3px rgba(232,82,26,.08); }
.form-input:focus-visible { outline:none; }
.form-input.invalid { border-color:var(--rd); }
.form-input.valid   { border-color:var(--gr); }
.form-input::placeholder { color:var(--gy3); }
select.form-input { cursor:pointer; }
textarea.form-input { resize:vertical; min-height:80px; line-height:1.5; }
.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
.form-hint  { font-size:11px; color:var(--gy4); margin-top:3px; }
.field-error { font-size:11px; color:var(--rd); margin-top:3px; display:none; font-weight:500; }

/* ── TABBED FORM ── */
.form-tabs { display:flex; gap:4px; margin-bottom:16px; background:var(--gy1); border-radius:var(--radius-lg); padding:4px; }
.form-tab-btn {
  flex:1; padding:7px 10px; border:none; background:none;
  border-radius:var(--radius); font-size:12px; font-weight:600;
  color:var(--gy4); cursor:pointer; transition:var(--transition);
  font-family:inherit;
}
.form-tab-btn.active { background:var(--wh); color:var(--or); box-shadow:var(--shadow-sm); }
.form-tab-btn:hover:not(.active) { color:var(--gy6); }
.form-tab-content { display:none; }
.form-tab-content.active { display:block; animation:tabIn .18s ease; }
@keyframes tabIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:none; } }

/* ── FILTERS BAR ── */
.filters-bar {
  background:var(--wh); border-radius:var(--radius-lg); padding:12px 16px;
  margin-bottom:14px; display:flex; gap:10px; flex-wrap:wrap; align-items:center;
  border:1px solid var(--gy2); box-shadow:var(--shadow-sm);
}
.search-wrap { position:relative; flex:1; min-width:180px; }
.search-icon { position:absolute; right:10px; top:50%; transform:translateY(-50%); color:var(--gy4); font-size:15px; pointer-events:none; }
.search-input {
  width:100%; padding:8px 34px 8px 12px; border:1.5px solid var(--gy2);
  border-radius:var(--radius); font-size:13px; font-family:inherit;
  color:var(--gy6); outline:none; background:var(--gy0); transition:border-color .15s;
}
.search-input:focus { border-color:var(--or); background:var(--wh); }
.filter-select {
  padding:8px 10px; border:1.5px solid var(--gy2); border-radius:var(--radius);
  font-size:12px; font-family:inherit; color:var(--gy6);
  outline:none; background:var(--gy0); cursor:pointer;
}
.filter-select:focus { border-color:var(--or); }

/* ── TABLE ── */
.table-wrap { overflow-x:auto; border-radius:var(--radius-lg); }
table { width:100%; border-collapse:collapse; font-size:13px; }
thead { background:var(--dk); }
thead th { padding:11px 14px; color:rgba(255,255,255,.9); font-weight:600; text-align:right; white-space:nowrap; font-size:12px; }
tbody tr { border-bottom:1px solid var(--gy2); transition:background .1s; }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background:var(--gy0); }
tbody td { padding:11px 14px; color:var(--gy6); vertical-align:middle; }

/* ── STEPS ── */
.steps-bar { display:flex; align-items:center; margin-bottom:20px; overflow-x:auto; padding-bottom:4px; }
.step-dot { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; border:2px solid var(--gy2); color:var(--gy4); background:var(--wh); flex-shrink:0; transition:var(--transition); }
.step-dot.done { background:var(--gr); border-color:var(--gr); color:#fff; }
.step-dot.active { background:var(--or); border-color:var(--or); color:#fff; }
.step-label { font-size:11px; color:var(--gy4); white-space:nowrap; }
.step-label.active { color:var(--or); font-weight:600; }
.step-label.done { color:var(--gr); }
.step-line { flex:1; height:2px; background:var(--gy2); margin:0 6px; min-width:20px; }
.step-line.done { background:var(--gr); }

/* ── PROGRESS BAR ── */
.progress { height:6px; background:var(--gy2); border-radius:999px; overflow:hidden; }
.progress-bar { height:100%; border-radius:999px; background:var(--or); transition:width .4s ease; }
.progress-bar.full { background:var(--gr); }

/* ── TIMELINE ── */
.timeline { padding-right:20px; }
.tl-item { position:relative; padding-bottom:14px; padding-right:22px; }
.tl-item::before { content:''; position:absolute; right:5px; top:8px; bottom:-6px; width:1px; background:var(--gy2); }
.tl-item:last-child::before { display:none; }
.tl-dot { position:absolute; right:0; top:3px; width:12px; height:12px; border-radius:50%; background:var(--or); border:2px solid var(--wh); box-shadow:0 0 0 2px var(--or); }
.tl-time { font-size:10px; color:var(--gy4); }
.tl-text { font-size:12px; color:var(--gy6); margin-top:1px; }

/* ── MODAL ── */
.overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.48); z-index:500; align-items:center; justify-content:center; padding:16px; }
.overlay.open { display:flex; animation:ovIn .15s ease; }
@keyframes ovIn { from { opacity:0; } to { opacity:1; } }
.modal {
  background:var(--wh); border-radius:var(--radius-xl);
  width:100%; max-width:520px; max-height:90vh;
  overflow:hidden; display:flex; flex-direction:column;
  box-shadow:var(--shadow-lg); animation:modalIn .2s ease;
}
.modal-lg { max-width:680px; }
.modal-xl { max-width:820px; }
@keyframes modalIn { from { opacity:0; transform:scale(.95) translateY(10px); } to { opacity:1; transform:none; } }
.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid var(--gy2); flex-shrink:0;
}
.modal-title { font-size:15px; font-weight:700; color:var(--gy6); }
.modal-body  { padding:20px; overflow-y:auto; flex:1; }
.modal-footer { padding:14px 20px; border-top:1px solid var(--gy2); display:flex; justify-content:flex-end; gap:8px; flex-shrink:0; align-items:center; flex-wrap:wrap; }

/* ── ALERTS ── */
.alert { display:flex; align-items:flex-start; gap:9px; padding:10px 14px; border-radius:var(--radius); margin-bottom:10px; font-size:12px; line-height:1.5; }
.alert-warn    { background:var(--am-lt); color:var(--am-dk); border:1px solid var(--am); }
.alert-danger  { background:var(--rd-lt); color:var(--rd-dk); border:1px solid var(--rd); }
.alert-info    { background:var(--bl-lt); color:var(--bl-dk); border:1px solid var(--bl); }
.alert-success { background:var(--gr-lt); color:var(--gr-dk); border:1px solid var(--gr); }

/* ── TOAST ── */
#toast-wrap {
  position:fixed; top:72px; left:50%; transform:translateX(-50%);
  z-index:9999; display:flex; flex-direction:column; gap:7px;
  pointer-events:none; max-width:340px; width:calc(100% - 32px);
}
.toast {
  background:var(--dk); color:#fff; padding:11px 15px;
  border-radius:var(--radius); font-size:13px; font-weight:500;
  box-shadow:var(--shadow-lg); animation:toastIn .25s ease;
  border-right:3px solid var(--or); line-height:1.4;
}
.toast.success { background:var(--gr-dk); border-right-color:var(--gr-lt); }
.toast.error   { background:var(--rd-dk); border-right-color:var(--rd-lt); }
.toast.warning { background:var(--am-dk); border-right-color:var(--am-lt); }
@keyframes toastIn { from { opacity:0; transform:translateX(-16px); } to { opacity:1; transform:none; } }

/* ── RESPONSIVE ── */
@media(max-width:600px) {
  .form-row, .form-row-3 { grid-template-columns:1fr; }
  .stats { grid-template-columns:repeat(2,1fr); }
  .gear-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .gear-thumb { height:120px; }
  .modal-footer { justify-content:stretch; }
  .modal-footer .btn { flex:1; justify-content:center; }
  .btn-full-mobile { width:100%; justify-content:center; }
}
@media(max-width:900px) {
  .gear-grid { grid-template-columns:repeat(auto-fill,minmax(165px,1fr)); gap:10px; }
  .gear-thumb { height:130px; }
}
