/* BSV - Anagrafica Search — July 2025 Brand Styles
Palette: Blue #0076BB, Orange #FE4C10, Neutral #0F172A / #F8FAFC
*/
:root{
  --bsv-blue:#0076BB;
  --bsv-orange:#FE4C10;
  --bsv-text:#0F172A;
  --bsv-muted:#475569;
  --bsv-bg:#F8FAFC;
  --bsv-card:#FFFFFF;
  --bsv-border:#E2E8F0;
}

.bsv-as-form{
  background:var(--bsv-card);
  padding:16px;
  border-radius:12px;
  color:var(--bsv-text);
  border:1px solid var(--bsv-border);
  box-shadow:0 2px 8px rgba(15,23,42,.06);
}

.bsv-as-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.bsv-as-field label{
  display:block;
  font-weight:600;
  margin-bottom:6px;
  color:var(--bsv-blue);
}

.bsv-as-field input{
  width:100%;
  padding:12px 14px;
  border:1.5px solid var(--bsv-border);
  border-radius:10px;
  background:#fff;
  color:var(--bsv-text);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.bsv-as-field input:focus{
  outline:none;
  border-color:var(--bsv-blue);
  box-shadow:0 0 0 3px rgba(0,118,187,.15);
}

.bsv-as-actions{
  margin-top:14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.bsv-as-btn{
  background:var(--bsv-orange);
  border:none;
  border-radius:10px;
  padding:12px 16px;
  color:#fff;
  cursor:pointer;
  font-weight:600;
  letter-spacing:.2px;
  transition:transform .06s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 2px 8px rgba(254,76,16,.25);
}
.bsv-as-btn:hover{ background:#ef4a0f; transform:translateY(-1px) }
.bsv-as-btn:active{ transform:translateY(0) }

.bsv-as-secondary{
  background:#ffffff;
  color:var(--bsv-blue);
  border:1.5px solid var(--bsv-blue);
  text-decoration:none;
  display:inline-block;
  box-shadow:none;
}
.bsv-as-secondary:hover{ background:#f0f9ff }

.bsv-as-results{ margin-top:18px }

.bsv-as-summary{
  margin-bottom:10px;
  color:var(--bsv-muted);
  font-size:.95rem;
}

.bsv-as-table-wrap{ overflow:auto }

.bsv-as-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:var(--bsv-card);
  border:1px solid var(--bsv-border);
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(15,23,42,.06);
}
.bsv-as-table th,
.bsv-as-table td{
  padding:12px 14px;
  border-bottom:1px solid var(--bsv-border);
  color:var(--bsv-text);
  background:#fff;
  text-align:left;
}
.bsv-as-table thead th{
  background:linear-gradient(0deg, #ffffff, #ffffff),
             linear-gradient(90deg, rgba(0,118,187,.08), rgba(254,76,16,.08));
  color:var(--bsv-text);
  font-weight:700;
  border-bottom:2px solid var(--bsv-border);
}
.bsv-as-table tr:nth-child(even) td{ background:#FAFCFE }

.bsv-as-pagination{
  display:flex;
  gap:8px;
  margin-top:12px;
  flex-wrap:wrap;
}
.bsv-as-pagination a{
  padding:8px 12px;
  border:1.5px solid var(--bsv-border);
  border-radius:10px;
  color:var(--bsv-text);
  text-decoration:none;
  background:#fff;
  transition:border-color .2s ease, color .2s ease, box-shadow .2s ease;
}
.bsv-as-pagination a:hover{
  border-color:var(--bsv-blue);
  color:var(--bsv-blue);
  box-shadow:0 0 0 3px rgba(0,118,187,.12);
}
.bsv-as-pagination a.current{
  background:var(--bsv-blue);
  border-color:var(--bsv-blue);
  color:#fff;
}

.bsv-as-empty{ color:var(--bsv-muted) }

@media (max-width:768px){
  .bsv-as-grid{ grid-template-columns:1fr }
}


/* Responsive table for mobile */
@media (max-width: 640px) {
  .bsv-as-table thead {
    display: none;
  }
  .bsv-as-table tr {
    display: block;
    margin-bottom: 12px;
    border: 1px solid var(--bsv-border);
    border-radius: 8px;
    overflow: hidden;
  }
  .bsv-as-table td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px;
    border: none;
    border-bottom: 1px solid var(--bsv-border);
  }
  .bsv-as-table td:last-child {
    border-bottom: none;
  }
  .bsv-as-table td::before {
    content: attr(data-label);
    font-weight: 600;
    color: var(--bsv-blue);
    flex: 1;
    text-align: left;
    padding-right: 10px;
  }
}

/* --- Responsive enhancements --- */
@media (max-width: 640px){
  .bsv-as-form{ padding:14px }
  .bsv-as-grid{ grid-template-columns:1fr; gap:12px }
  .bsv-as-actions{ gap:8px }
  .bsv-as-table-wrap{ overflow:visible }
  .bsv-as-table.bsv-as-table--responsive thead{
    display:none;
  }
  .bsv-as-table.bsv-as-table--responsive tr{
    display:block;
    margin-bottom:10px;
    border:1px solid var(--bsv-border);
    border-radius:10px;
    overflow:hidden;
    box-shadow:0 1px 4px rgba(15,23,42,.06);
    background:#fff;
  }
  .bsv-as-table.bsv-as-table--responsive td{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:10px 12px;
    border-bottom:1px solid var(--bsv-border);
  }
  .bsv-as-table.bsv-as-table--responsive td:last-child{
    border-bottom:none;
  }
  .bsv-as-table.bsv-as-table--responsive td::before{
    content:attr(data-label);
    font-weight:600;
    color:var(--bsv-muted);
    margin-right:12px;
  }
}
