/* Reusable components */

.btn{
  appearance:none;
  border: 1px solid transparent;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 650;
  cursor:pointer;
  background: rgba(255,255,255,.70);
  color: var(--c-text);
}

.btn:hover{ filter: brightness(.98); }
.btn:active{ transform: translateY(1px); }

.btn-primary{
  background: var(--c-primary);
  color: white;
}
.btn-primary:hover{ filter: brightness(1.05); }

.btn-secondary{
  border-color: var(--c-divider);
  background: rgba(255,255,255,.75);
}

.btn-danger{
  background: var(--c-danger);
  color: white;
}

.btn-ghost{
  background: transparent;
  border-color: var(--c-divider);
}

.btn-small{
  padding: 8px 10px;
  border-radius: 10px;
  font-size: 13px;
}

.tab{
  padding: 9px 12px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  font-weight: 700;
  color: rgba(30,26,36,.78);
}
.tab[aria-current="page"]{
  background: white;
  border-color: var(--c-divider);
  color: var(--c-text);
  box-shadow: var(--shadow-sm);
}

.card{
  border: 1px solid var(--c-divider);
  border-radius: var(--radius);
  background: rgba(255,255,255,.72);
  box-shadow: var(--shadow-sm);
}

.card.pad{ padding: 16px; }

.grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 820px){
  .grid-2{ grid-template-columns: 1fr; }
}

.row{
  display:flex;
  gap: 10px;
  align-items:center;
  flex-wrap: wrap;
}

.field{
  display:flex;
  flex-direction: column;
  gap: 6px;
  min-width: 180px;
}
.label{
  font-size: 12px;
  color: rgba(30,26,36,.72);
}
.input, select{
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--c-divider);
  border-radius: 12px;
  background: rgba(255,255,255,.92);
  color: var(--c-text);
}
.input::placeholder{ color: rgba(30,26,36,.50); }

.badge{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--c-divider);
  font-size: 12px;
  background: rgba(255,255,255,.65);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--c-divider);
  background: rgba(255,255,255,.65);
}

.h1{ font-size: 20px; font-weight: 820; margin: 0 0 8px; }
.h2{ font-size: 16px; font-weight: 780; margin: 0 0 10px; }
.p{ margin: 0; color: rgba(30,26,36,.78); line-height: 1.45; }

.table{
  width:100%;
  border-collapse: collapse;
}
.table th, .table td{
  border-bottom: 1px solid var(--c-divider);
  padding: 10px 8px;
  text-align:left;
  vertical-align: top;
  font-size: 13px;
}
.table th{
  font-size: 12px;
  color: rgba(30,26,36,.72);
  font-weight: 760;
}

.split{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
}
@media (max-width: 980px){
  .split{ grid-template-columns: 1fr; }
}

.notice{
  border: 1px dashed rgba(91,42,134,.35);
  background: rgba(91,42,134,.06);
  border-radius: var(--radius);
  padding: 12px;
}

.toast{
  position: fixed;
  right: 18px;
  bottom: 18px;
  max-width: 360px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,.88);
  border: 1px solid var(--c-divider);
  box-shadow: var(--shadow);
  z-index: 50;
}

.lock{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  font-size: 12px;
  color: rgba(30,26,36,.78);
}
.lock svg{ width: 14px; height: 14px; }
