/* Cards */
[hidden]{display:none !important;}

.card{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid var(--border);
  border-radius: var(--r-3);
  box-shadow: var(--shadow-2);
}
.card__header{padding: var(--space-6); border-bottom: 1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap: var(--space-4)}
.card__title{margin:0; font-size: var(--fs-3); font-weight: 700}
.card__body{padding: var(--space-6)}
.card__footer{padding: var(--space-6); border-top: 1px solid var(--border)}

.kpis{display:grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5)}
@media (max-width: 980px){.kpis{grid-template-columns: 1fr 1fr}}
@media (max-width: 560px){.kpis{grid-template-columns: 1fr}}

.kpi{padding: var(--space-6)}
.kpi__label{font-size: var(--fs-1); color: var(--muted)}
.kpi__value{font-size: 1.75rem; font-weight: 800; margin-top: var(--space-2)}
.kpi__hint{margin-top: var(--space-2); font-size: var(--fs-1); color: var(--muted-2)}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: .55rem;
  padding: .7rem 1rem;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  text-decoration:none;
  cursor:pointer;
  font-weight: 650;
  line-height: 1;
}
.btn:hover{background: rgba(255,255,255,.07)}
.btn:active{transform: translateY(1px)}
.btn--primary{background: linear-gradient(135deg, var(--primary), var(--primary-2)); border-color: rgba(109,94,252,.35)}
.btn--primary:hover{filter: brightness(1.04)}
.btn--danger{background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.30)}
.btn--ghost{background: transparent}
.btn--sm{padding: .5rem .75rem; border-radius: 10px; font-size: var(--fs-1)}
.btn[disabled], .btn[aria-disabled="true"]{opacity:.55; cursor:not-allowed}

/* Badges */
.badge{
  display:inline-flex;
  align-items:center;
  gap: .4rem;
  padding: .32rem .55rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: var(--fs-1);
  color: var(--muted);
  background: rgba(255,255,255,.04);
}
.badge--success{color: color-mix(in srgb, var(--success) 90%, var(--text)); border-color: rgba(34,197,94,.35); background: rgba(34,197,94,.10)}
.badge--warning{color: color-mix(in srgb, var(--warning) 90%, var(--text)); border-color: rgba(245,158,11,.35); background: rgba(245,158,11,.10)}
.badge--danger{color: color-mix(in srgb, var(--danger) 90%, var(--text)); border-color: rgba(239,68,68,.35); background: rgba(239,68,68,.10)}
.badge--info{color: color-mix(in srgb, var(--info) 90%, var(--text)); border-color: rgba(56,189,248,.35); background: rgba(56,189,248,.10)}
.badge--muted{color: var(--muted)}

/* Tables (responsive) */
.table{width:100%; border-collapse: collapse}
.table th, .table td{padding: .9rem .75rem; border-bottom: 1px solid var(--border); vertical-align: top}
.table th{font-size: var(--fs-1); text-transform: uppercase; letter-spacing: .08em; color: var(--muted-2); text-align:left}
.table tr:hover td{background: rgba(255,255,255,.03)}
.table__actions{display:flex; gap: .5rem; justify-content:flex-end; flex-wrap: wrap}

@media (max-width: 720px){
  .table thead{display:none}
  .table, .table tbody, .table tr, .table td{display:block; width:100%}
  .table tr{border: 1px solid var(--border); border-radius: 16px; overflow:hidden; margin-bottom: var(--space-4); background: rgba(255,255,255,.03)}
  .table td{border:0; display:flex; justify-content: space-between; gap: var(--space-4)}
  .table td::before{content: attr(data-label); color: var(--muted-2); text-transform: uppercase; letter-spacing: .08em; font-size: 12px}
  .table__actions{justify-content:flex-start}
}

@media (max-width: 420px){
  .table td{flex-direction:column; align-items:flex-start}
  .table td::before{margin-bottom: .25rem}
}

/* Toolbar */
.toolbar{display:flex; gap: var(--space-3); flex-wrap: wrap; align-items:center}
.search{
  display:flex; align-items:center; gap: .6rem;
  padding: .6rem .8rem;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  min-width: min(520px, 100%);
}
.search input{border:0; outline:0; background: transparent; color: var(--text); width:100%; font-size: var(--fs-2)}
.search input::placeholder{color: var(--muted-2)}

/* Toasts */
.toasts{position: fixed; right: var(--space-6); top: var(--space-6); z-index: var(--z-toast); display:flex; flex-direction:column; gap: var(--space-3); max-width: min(420px, calc(100vw - 2rem));}
.toast{
  border-radius: 16px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 75%, transparent);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-1);
  padding: .9rem 1rem;
  display:flex;
  gap: .8rem;
  align-items:flex-start;
}
.toast__title{font-weight: 800; margin:0}
.toast__msg{margin:.1rem 0 0; color: var(--muted)}
.toast__close{margin-left:auto}
.toast--success{border-color: rgba(34,197,94,.35)}
.toast--danger{border-color: rgba(239,68,68,.35)}
.toast--info{border-color: rgba(56,189,248,.35)}
.toast--warning{border-color: rgba(245,158,11,.35)}

/* Modal */
.modal{position: fixed; inset:0; display:none; align-items:center; justify-content:center; padding: var(--space-6); z-index: var(--z-overlay)}
.modal.is-open{display:flex}
.modal__overlay{position:absolute; inset:0; background: rgba(0,0,0,.55)}
.modal__panel{position: relative; width: min(520px, 100%); border-radius: 18px; border: 1px solid var(--border); background: var(--surface); box-shadow: var(--shadow-1)}
.modal__header{padding: var(--space-6); border-bottom: 1px solid var(--border)}
.modal__body{padding: var(--space-6); color: var(--muted)}
.modal__footer{padding: var(--space-6); border-top: 1px solid var(--border); display:flex; justify-content:flex-end; gap: var(--space-3)}

@media (max-width: 560px){
  .card__header{padding: var(--space-5); flex-wrap: wrap; align-items:flex-start}
  .card__body{padding: var(--space-5)}
  .card__footer{padding: var(--space-5)}

  .toolbar{align-items:stretch}
  .search{min-width: 100%}

  .toasts{left: var(--space-4); right: var(--space-4); top: var(--space-4)}

  .modal{padding: var(--space-4)}
  .modal__footer{flex-direction:column-reverse; align-items:stretch}
}
