/* ── Components — buttons, modals, forms, badges, toasts ────── */

/* Buttons */
.btn-sm{font-size:12px;font-weight:600;padding:6px 14px;border-radius:99px;border:none;cursor:pointer;transition:all .15s;letter-spacing:-.01em}
.btn-primary{background:var(--green);color:var(--bg)}.btn-primary:hover{background:#bef264}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border2)}.btn-ghost:hover{color:var(--text);border-color:var(--muted2)}
.btn-danger{background:transparent;color:var(--down);border:1px solid rgba(248,113,113,.3)}.btn-danger:hover{background:rgba(248,113,113,.08)}

/* Forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,
.field select,
.field textarea{
  width:100%;padding:9px 12px;
  background:var(--bg);border:1px solid var(--border2);
  border-radius:8px;color:var(--text);
  font-family:var(--body);font-size:13px;
  outline:none;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(163,230,53,.1)}
.field input::placeholder{color:var(--muted2)}
.field select option{background:var(--surface)}
.field textarea{resize:vertical;min-height:60px}

/* Auth card (login, signup, forgot, set-password) */
.auth-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;position:relative;overflow:hidden}
.auth-wrap::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(163,230,53,0.07) 0%,transparent 60%);pointer-events:none}
.auth-logo{margin-bottom:32px;text-align:center}
.auth-logo a{font-family:var(--display);font-size:26px;color:var(--green);text-decoration:none}
.auth-logo p{font-size:13px;color:var(--muted);margin-top:4px}
.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.auth-btn{width:100%;padding:12px;border:none;border-radius:99px;background:var(--green);color:var(--bg);font-family:var(--body);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;margin-top:8px;letter-spacing:-.01em}
.auth-btn:hover{background:#bef264;transform:translateY(-1px)}
.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.auth-divider{height:1px;background:var(--border);margin:18px 0}
.auth-links{text-align:center;font-size:13px;color:var(--muted)}
.auth-links a{color:var(--green-mid);text-decoration:none;transition:color .15s}.auth-links a:hover{color:var(--green)}
.auth-err{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);color:var(--down);font-size:13px;padding:10px 14px;border-radius:8px;margin-bottom:14px;line-height:1.5}
.auth-msg{padding:10px 14px;border-radius:8px;font-size:12px;margin-top:12px;display:none}
.auth-msg.ok{background:rgba(163,230,53,.1);color:var(--green);border:1px solid rgba(163,230,53,.2)}
.auth-msg.err{background:rgba(248,113,113,.08);color:var(--down);border:1px solid rgba(248,113,113,.2)}

/* Modals */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:460px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.modal-lg{max-width:680px}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}
.modal-title{font-family:var(--display);font-size:16px;color:var(--text)}
.modal-close{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;line-height:1;padding:4px}.modal-close:hover{color:var(--text)}
.modal-body{padding:22px}
.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}

/* Badges */
.badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:99px;letter-spacing:.04em}
.badge-admin{background:rgba(251,146,60,.1);color:var(--warn)}
.badge-user{background:rgba(107,127,107,.1);color:var(--muted)}
.badge-active{background:rgba(163,230,53,.1);color:var(--up)}
.badge-inactive{background:rgba(248,113,113,.1);color:var(--down)}
.badge-trial{background:rgba(163,230,53,.08);color:var(--green);border:1px solid rgba(163,230,53,.15)}
.badge-180{background:rgba(251,146,60,.08);color:var(--warn);border:1px solid rgba(251,146,60,.15)}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 18px;font-size:13px;box-shadow:0 8px 30px rgba(0,0,0,.4);z-index:300;transform:translateY(80px);opacity:0;transition:all .25s}
.toast.show{transform:translateY(0);opacity:1}
.toast.ok{border-color:rgba(163,230,53,.4);color:var(--up)}
.toast.err{border-color:rgba(248,113,113,.4);color:var(--down)}

/* Status badges */
.status-badge{font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;border-radius:99px;flex-shrink:0}
.badge-up{background:rgba(163,230,53,.12);color:var(--up)}
.badge-down{background:rgba(248,113,113,.12);color:var(--down)}
.badge-warn{background:rgba(251,146,60,.12);color:var(--warn)}
.badge-unknown{background:rgba(107,127,107,.12);color:var(--muted)}

/* Plan badge */
.plan-badge{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;border-radius:99px;background:var(--green-dim);color:var(--green);border:1px solid rgba(163,230,53,.2)}

/* Inline status message */
.status-msg{font-size:12px;padding:5px 10px;border-radius:99px}
.status-msg.ok{background:rgba(163,230,53,.1);color:var(--up)}
.status-msg.err{background:rgba(248,113,113,.1);color:var(--down)}

/* Section cards (settings, admin) */
.section{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:18px}
.section-header{padding:14px 18px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--surface2)}
.section-body{padding:18px}
.section-footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:10px;align-items:center;background:var(--surface2)}

/* Grid rows */
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.row.single{grid-template-columns:1fr}
@media(max-width:600px){.row{grid-template-columns:1fr}}

/* Tables (admin) */
table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--surface2);border-bottom:1px solid var(--border)}
td{padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.015)}
.table-empty{text-align:center;padding:48px 20px;color:var(--muted);font-size:13px}

/* Action buttons (tables) */
.action-btn{font-size:11px;font-weight:500;padding:4px 10px;border-radius:99px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}
.action-btn:hover{color:var(--text2);border-color:var(--muted2)}
.action-btn.red:hover{color:var(--down);border-color:rgba(248,113,113,.4)}

/* Plan select (admin table) */
.plan-sel{font-size:12px;background:var(--bg);border:1px solid var(--border2);color:var(--text);border-radius:99px;padding:3px 10px;cursor:pointer;outline:none}

/* Hint text */
.hint{font-size:12px;color:var(--muted);margin-top:10px;line-height:1.6}
.hint code{font-size:11px;background:var(--surface2);padding:1px 6px;border-radius:4px}
