/* /assets/css/components.css */
/* Buttons, cards, tables, chips, forms, FAQ, badges */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.75rem 1rem;
  border-radius: 14px;
  border:1px solid transparent;
  background: var(--brand);
  color:#fff;
  font-weight: 700;
  font-size: .95rem;
  text-decoration:none;
  cursor:pointer;
  box-shadow: 0 10px 20px rgba(2,6,23,.10);
}
.btn:hover{
  background:#111827;
  text-decoration:none;
}
.btn:active{ transform: translateY(1px); }

.btn-ghost{
  background: var(--surface);
  color: var(--text);
  border-color: var(--line);
  box-shadow: none;
}
.btn-ghost:hover{
  background: var(--surface-2);
}

.btn-small{
  padding:.55rem .85rem;
  border-radius: 12px;
  font-size: .9rem;
}

/* Cards */
.card{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(1rem, 2.5vw, 1.5rem);
  box-shadow: var(--shadow-1);
}
.card-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
}
.card-grid > .card,
.card-grid > article.card{
  grid-column: span 12;
}
@media (min-width: 720px){
  .card-grid > .card,
  .card-grid > article.card{ grid-column: span 6; }
}
@media (min-width: 1040px){
  .card-grid > .card,
  .card-grid > article.card{ grid-column: span 4; }
}

.card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  margin-bottom:.75rem;
}
.card-title{
  margin:0 0 .5rem;
}
.card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:.75rem;
  color: var(--muted);
  font-size: .9rem;
}
.card-link{
  display:inline-flex;
  margin-top: .9rem;
  font-weight: 800;
  color: var(--accent);
  text-decoration:none;
}
.card-link:hover{ text-decoration:underline; }

/* Badge + price band */
.badge{
  display:inline-flex;
  align-items:center;
  padding:.25rem .55rem;
  border-radius: 999px;
  background: rgba(37,99,235,.10);
  border: 1px solid rgba(37,99,235,.20);
  color: #1e3a8a;
  font-size: .8rem;
  font-weight: 700;
}
.price-band{
  font-size: .85rem;
  font-weight: 800;
  color: var(--muted);
}

/* Chips */
.chips{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top:.75rem;
}
.chip{
  display:inline-flex;
  align-items:center;
  padding:.25rem .55rem;
  border-radius: 999px;
  background: var(--surface-2);
  border:1px solid var(--line);
  color: var(--text);
  font-size: .8rem;
  font-weight: 600;
}

/* Lists */
.bullets{
  margin: .25rem 0 0;
  padding-left: 1.1rem;
}
.bullets li{ margin: .4rem 0; }

.checklist{
  list-style:none;
  padding:0;
  margin:.25rem 0 0;
}
.checklist li{
  position:relative;
  padding-left: 1.75rem;
  margin:.45rem 0;
}
.checklist li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:.02rem;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 999px;
  display:grid;
  place-items:center;
  font-weight: 900;
  color:#fff;
  background: var(--ok);
  box-shadow: 0 6px 14px rgba(22,163,74,.20);
}

/* Forms */
label span{
  display:block;
  font-size: .85rem;
  color: var(--muted);
  margin-bottom: .35rem;
  font-weight: 700;
}
input[type="text"], input[type="email"], input[type="search"], input[type="tel"], textarea, select{
  width:100%;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text);
  border-radius: 14px;
  padding: .75rem .9rem;
  font: inherit;
}
textarea{ min-height: 140px; resize: vertical; }
select{ cursor:pointer; }

.filters{
  display:grid;
  gap: .75rem;
  grid-template-columns: 1fr;
  margin-bottom: 1rem;
}
@media (min-width: 860px){
  .filters{ grid-template-columns: 1.2fr .8fr .8fr auto auto; align-items:end; }
}

.results-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  margin: .75rem 0 1rem;
  flex-wrap:wrap;
}

/* Tables (professional) */
table{
  width:100%;
  border-collapse: collapse;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow:hidden;
}
th, td{
  padding: .75rem;
  border-bottom: 1px solid var(--line);
  text-align:left;
  vertical-align: top;
}
th{
  background: var(--surface-2);
  font-weight: 800;
  color: var(--text);
  font-size: .92rem;
}
tr:last-child td{ border-bottom:none; }

/* FAQ */
details{
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: .75rem .9rem;
  background: var(--surface);
}
details + details{ margin-top: .75rem; }
summary{
  cursor:pointer;
  font-weight: 800;
}
details p{ margin-top: .6rem; }

/* Partner module */
.partner{
  margin-top: 1.25rem;
  background: linear-gradient(180deg, rgba(37,99,235,.08), rgba(37,99,235,.03));
  border: 1px solid rgba(37,99,235,.18);
  border-radius: var(--r-lg);
  padding: 1.25rem;
}
.partner .btn{ background: var(--accent); }
.partner .btn:hover{ background:#1d4ed8; }

/* Simple grid helper */
.grid-2{
  display:grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}
@media (min-width: 920px){
  .grid-2{ grid-template-columns: 1fr 1fr; }
}

.actions{
  display:flex;
  flex-wrap:wrap;
  gap: .75rem;
  margin-top: 1rem;
}