/* ============================================================
   WBR components — reusable pieces (buttons, cards, badges,
   forms, lists, timeline, toast, alerts). Used across all pages.
   ============================================================ */

/* ---- Buttons ---- */
.wbr-btn{font-family:inherit;font-weight:600;font-size:14px;border-radius:var(--wbr-radius);padding:9px 15px;cursor:pointer;border:1px solid var(--wbr-brand);background:var(--wbr-brand);color:#fff;display:inline-flex;align-items:center;gap:7px;line-height:1.1;transition:background .15s,border-color .15s}
.wbr-btn:hover{background:var(--wbr-brand-2);border-color:var(--wbr-brand-2)}
.wbr-btn:active{transform:translateY(1px)}
.wbr-btn-ghost{background:transparent;color:var(--wbr-brand)}
.wbr-btn-ghost:hover{background:var(--wbr-brand-tint);color:var(--wbr-brand)}
.wbr-btn-muted{background:transparent;color:var(--wbr-muted);border-color:var(--wbr-border)}
.wbr-btn-muted:hover{background:var(--wbr-page)}
.wbr-btn-sm{padding:6px 11px;font-size:12.5px}
.wbr-btn-block{width:100%;justify-content:center;padding:12px}

/* ---- Page header + cards ---- */
.wbr-page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.wbr-page-head h1{font-size:20px;margin:0}
.wbr-card{background:var(--wbr-card);border:1px solid var(--wbr-border);border-radius:var(--wbr-radius-lg);box-shadow:var(--wbr-shadow);padding:16px 18px}
.wbr-section-label{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--wbr-muted);margin:0 0 11px}

/* ---- Action / KPI cards ---- */
.wbr-action{display:flex;align-items:center;gap:14px;background:var(--wbr-card);border:1px solid var(--wbr-border);border-radius:var(--wbr-radius-lg);box-shadow:var(--wbr-shadow);padding:14px 16px;margin-bottom:11px}
.wbr-chip{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.wbr-chip-ok{background:var(--wbr-ok-tint);color:var(--wbr-brand)}
.wbr-chip-info{background:var(--wbr-info-tint);color:var(--wbr-info)}
.wbr-chip-warn{background:var(--wbr-warn-tint);color:var(--wbr-warn)}
.wbr-chip-danger{background:var(--wbr-danger-tint);color:var(--wbr-danger)}
.wbr-action-body{flex:1;min-width:0}
.wbr-action-title{font-size:15px;font-weight:600}
.wbr-action-sub{font-size:12.5px;color:var(--wbr-muted);margin-top:1px}

/* ---- Badges ---- */
.wbr-badge{font-size:12px;font-weight:600;padding:4px 11px;border-radius:20px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.wbr-badge-ok{background:var(--wbr-ok-tint);color:var(--wbr-brand)}
.wbr-badge-info{background:var(--wbr-info-tint);color:var(--wbr-info)}
.wbr-badge-warn{background:var(--wbr-warn-tint);color:var(--wbr-warn)}
.wbr-badge-danger{background:var(--wbr-danger-tint);color:var(--wbr-danger)}

/* ---- Forms ---- */
.wbr-field{margin-bottom:14px}
.wbr-label{font-size:13px;font-weight:600;display:block;margin-bottom:6px}
.wbr-input,.wbr-select,.wbr-textarea{font-family:inherit;font-size:14px;color:var(--wbr-text);background:var(--wbr-card);border:1px solid var(--wbr-border);border-radius:var(--wbr-radius);padding:10px 12px;width:100%}
.wbr-input:focus,.wbr-select:focus,.wbr-textarea:focus{outline:none;border-color:var(--wbr-brand);box-shadow:0 0 0 3px var(--wbr-brand-tint)}
.wbr-input[readonly]{background:var(--wbr-page);color:var(--wbr-muted)}
.wbr-textarea{min-height:90px;resize:vertical}
.wbr-help{font-size:11.5px;color:var(--wbr-muted);margin-top:5px;display:flex;align-items:center;gap:4px}
.wbr-help a{color:var(--wbr-brand);font-weight:600}
.wbr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}
.wbr-seg{display:inline-flex;border:1px solid var(--wbr-border);border-radius:var(--wbr-radius);overflow:hidden}
.wbr-seg button{font-family:inherit;font-size:13px;font-weight:600;padding:8px 16px;border:none;background:transparent;color:var(--wbr-muted);cursor:pointer}
.wbr-seg button.is-on{background:var(--wbr-brand);color:#fff}
.wbr-check{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;cursor:pointer;margin:4px 14px 4px 0}
.wbr-check input{width:16px;height:16px;accent-color:var(--wbr-brand)}

/* ---- Responsive lists / rows ---- */
.wbr-list-row{display:flex;align-items:center;gap:13px;background:var(--wbr-card);border:1px solid var(--wbr-border);border-radius:var(--wbr-radius-lg);box-shadow:var(--wbr-shadow);padding:11px 14px;margin-bottom:8px;flex-wrap:wrap}
.wbr-fileicon{width:38px;height:38px;border-radius:10px;background:var(--wbr-brand-tint);color:var(--wbr-brand);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.wbr-row-body{flex:1;min-width:130px}
.wbr-row-title{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis}
.wbr-row-sub{font-size:12.5px;color:var(--wbr-muted);margin-top:1px}
.wbr-amt{font-size:14px;font-weight:700;white-space:nowrap}
.wbr-icon-action{width:34px;height:34px;border:1px solid var(--wbr-border);background:transparent;color:var(--wbr-muted);border-radius:var(--wbr-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px}
.wbr-icon-action:hover{border-color:var(--wbr-brand);color:var(--wbr-brand)}
.wbr-icon-action.is-danger:hover{border-color:var(--wbr-danger);color:var(--wbr-danger)}
.wbr-pw{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--wbr-border);background:transparent;border-radius:var(--wbr-radius);padding:5px 9px;font-family:inherit;font-size:12px;color:var(--wbr-muted);cursor:pointer}
.wbr-pw:hover{border-color:var(--wbr-brand);color:var(--wbr-brand)}

/* ---- Filter bar ---- */
.wbr-filter{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.wbr-filter .wbr-label{margin:0;font-size:11px;color:var(--wbr-muted)}
.wbr-filter .wbr-select,.wbr-filter .wbr-input{width:auto}
.wbr-filter .wbr-search{flex:1;min-width:140px}

/* ---- Dropzone ---- */
.wbr-dropzone{border:2px dashed var(--wbr-border);border-radius:var(--wbr-radius-lg);padding:20px;text-align:center;color:var(--wbr-muted);background:var(--wbr-card);cursor:pointer;margin-bottom:18px}
.wbr-dropzone:hover{border-color:var(--wbr-brand);color:var(--wbr-brand)}
.wbr-dropzone i{font-size:26px;display:block;margin-bottom:6px}
.wbr-dropzone b{color:var(--wbr-text);font-weight:600}

/* ---- Member grid ---- */
.wbr-member-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}

/* ---- Timeline / stepper ---- */
.wbr-steps{display:flex;align-items:flex-start}
.wbr-step{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;width:64px}
.wbr-bub{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;border:2px solid var(--wbr-border);color:var(--wbr-muted);background:var(--wbr-card)}
.wbr-step.is-done .wbr-bub{background:var(--wbr-brand);border-color:var(--wbr-brand);color:#fff}
.wbr-step.is-now .wbr-bub{border-color:var(--wbr-brand);color:var(--wbr-brand);box-shadow:0 0 0 4px var(--wbr-brand-tint)}
.wbr-step-label{font-size:11.5px;color:var(--wbr-muted);text-align:center;font-weight:500}
.wbr-step.is-done .wbr-step-label,.wbr-step.is-now .wbr-step-label{color:var(--wbr-text)}
.wbr-bar{flex:1;height:2px;background:var(--wbr-border);margin-top:14px;border-radius:2px}
.wbr-bar.is-done{background:var(--wbr-brand)}
.wbr-legend{display:flex;gap:16px;flex-wrap:wrap;margin:16px 0;font-size:12px;color:var(--wbr-muted)}
.wbr-legend span{display:inline-flex;align-items:center;gap:6px}
.wbr-dot{width:11px;height:11px;border-radius:50%}
.wbr-next{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;background:var(--wbr-brand-tint);border-radius:11px;padding:11px 14px}
.wbr-next-text{font-size:13px;font-weight:500;color:var(--wbr-brand-2)}
[data-theme="dark"] .wbr-next-text{color:var(--wbr-brand)}
/* Stepper stacks vertically on phones so labels never crowd */
@media(max-width:560px){
  .wbr-steps{flex-direction:column;align-items:stretch}
  .wbr-step{flex-direction:row;width:auto;gap:12px;justify-content:flex-start}
  .wbr-step-label{text-align:left}
  .wbr-bar{flex:none;width:2px;height:16px;margin:1px 0 1px 14px}
}

/* ---- Toast + alerts ---- */
.wbr-toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(10px);background:#16241c;color:#fff;font-size:13.5px;font-weight:500;padding:10px 18px;border-radius:var(--wbr-radius);opacity:0;visibility:hidden;transition:.2s;z-index:60;box-shadow:0 6px 22px rgba(0,0,0,.25);max-width:90vw;text-align:center}
.wbr-toast.is-show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.wbr-alert{display:flex;align-items:center;gap:9px;border-radius:var(--wbr-radius);padding:11px 14px;font-size:13.5px;font-weight:500;margin-bottom:14px}
.wbr-alert-success{background:var(--wbr-ok-tint);color:var(--wbr-brand-2)}
.wbr-alert-danger{background:var(--wbr-danger-tint);color:var(--wbr-danger)}
.wbr-alert-warn{background:var(--wbr-warn-tint);color:var(--wbr-warn)}
[data-theme="dark"] .wbr-alert-success{color:var(--wbr-brand)}

/* ---- Empty state ---- */
.wbr-empty{text-align:center;color:var(--wbr-muted);padding:40px 20px}
.wbr-empty i{font-size:34px;display:block;margin-bottom:10px;opacity:.7}

/* ---- OTP (login) ---- */
.wbr-otp{display:flex;gap:8px;justify-content:center;margin:6px 0}
.wbr-otp input{width:44px;height:52px;text-align:center;font-family:inherit;font-size:21px;font-weight:600;color:var(--wbr-text);background:var(--wbr-card);border:1px solid var(--wbr-border);border-radius:var(--wbr-radius)}
.wbr-otp input:focus{outline:none;border-color:var(--wbr-brand);box-shadow:0 0 0 3px var(--wbr-brand-tint)}
.wbr-auth-wrap{min-height:calc(100vh - var(--wbr-topbar-h));display:flex;align-items:center;justify-content:center;padding:20px}
.wbr-auth-card{width:100%;max-width:380px}
@media(max-width:430px){.wbr-otp input{width:40px;height:48px;font-size:19px}}
