/* =========================================================
   GBI — Style List Table
   ---------------------------------------------------------
   Scope:
   - Styles only the [gbi_all_styles] table + its toolbar.
   - Desktop: grouped core/variant rows with subtle visual hierarchy.
   - Mobile: converts the table into stacked “cards” with consistent
     label alignment and reduced visual noise.
   Notes:
   - This file intentionally contains ONLY table-related CSS.
   - Mobile rules are consolidated to avoid duplicated overrides.
   ========================================================= */

/* =========================================================
   1) WRAPPER + TOOLBAR (desktop first)
   ========================================================= */

.gbi-style-table-wrapper{
  width: fit-content;      /* krimpt naar inhoud */
  max-width: 100%;         /* nooit overflow */
  margin: 1.5rem auto;     /* centreer */
  border-radius: 8px;
  border: 1px solid #e3e6ec;
  background: #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,0.04);
  overflow: hidden;
}

.gbi-style-table-wrapper .gbi-style-table-toolbar{
  padding: 0.75rem 1rem 0.6rem;
  border-bottom: 1px solid #e5e7eb;
}

.gbi-core-cluster-intro{
  max-width: 900px;
  margin: 1.2rem auto 0.5rem;
  font-size: 0.95rem;
  color: #4b5563;
  line-height: 1.5;
}

@media (min-width: 901px){
  .gbi-style-table-wrapper .gbi-style-table-toolbar{
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 16px;
    align-items: end;
  }

  .gbi-style-table-wrapper .gbi-style-table-toolbar__group{
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
  }

  .gbi-style-table-wrapper .gbi-style-table-toolbar__group:nth-child(1){ align-items: flex-start; }
  .gbi-style-table-wrapper .gbi-style-table-toolbar__group:nth-child(2){ align-items: center; text-align: center; }
  .gbi-style-table-wrapper .gbi-style-table-toolbar__group:nth-child(3){ align-items: flex-end; text-align: right; min-width: 260px; }
}

.gbi-style-table-wrapper .gbi-style-table-toolbar label{
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #6b7280;
}

.gbi-style-table-wrapper select.gbi-style-table-family,
.gbi-style-table-wrapper input.gbi-style-table-search{
  padding: 0.3rem 0.45rem;
  font-size: 0.9rem;
  border-radius: 6px;
  border: 1px solid #d1d5db;
  width: 100%;
  max-width: 420px;
  box-sizing: border-box;
}
.gbi-style-table-wrapper input.gbi-style-table-search{ max-width: 320px; }

/* =========================================================
   2) TABLE BASE (desktop)
   ========================================================= */

.gbi-style-table{
  width: auto;
  border-collapse: collapse;
  font-size: 0.92rem;
  line-height: 1.35;
  table-layout: auto;   /* belangrijk */
}

.gbi-style-table thead th{
  padding: 0.45rem 0.7rem;
  text-align: left;
  font-weight: 600;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
  background: #f4f5f7;
  border-bottom: 2px solid #d6d8dd;
}

.gbi-style-table td{
    padding: 0.4rem 0.7rem;
  border-bottom: 1px solid #f1f3f6;
  vertical-align: middle;
}

.gbi-style-table__guide-col{
  width: 1%;
  white-space: nowrap;
}

/* Grouping core / variant */
.gbi-style-table tbody tr[data-style-tier="core"]{ background: #f8fafc; }
.gbi-style-table tbody tr[data-style-tier="core"] td{ border-top: 2px solid #d6d8dd; }
.gbi-style-table tbody tr[data-style-tier="core"]:first-child td{ border-top: none; }

.gbi-style-table tbody tr[data-style-tier="variant"]{ background: #fff; }

/* Variant indent + branch marker (desktop only) */
.gbi-style-table tbody tr[data-style-tier="variant"] td[data-label="Style"]{
  padding-left: 1.8rem;
  position: relative;
}

.gbi-style-table tbody tr[data-style-tier="variant"] td[data-label="Style"]::after{
  content: "";
  position: absolute;
  left: 0.9rem;
  top: 50%;
  width: 10px;
  height: 1px;
  background: #d6d8dd;
  transform: translateY(-50%);
}

/* Prevent thick separators inside a core group (if family label changes) */
.gbi-style-table tbody tr[data-style-tier="variant"].gbi-style-table__family-separator td{
  border-top: none !important;
}

/* Hover */
.gbi-style-table tbody tr:hover{ background: #fff8e6; }

/* Links */
.gbi-style-table__style-link{
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.gbi-style-table__style-link:hover,
.gbi-style-table__style-link:focus{ border-bottom-color: currentColor; }

.gbi-style-table__family-link{
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Variant badge (desktop) */
.gbi-style-tier-badge{
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  padding: 2px 8px;
  border: 1px solid #cfd6df;
  border-radius: 999px;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap;
  vertical-align: middle;
}

.gbi-style-tier-badge span{
  margin: 0 0.35em;
  opacity: 0.65;
  white-space: nowrap;
}

.gbi-variant-parent-link{
  text-decoration: underline;
  white-space: nowrap;
}

/* Guide chip */
.gbi-style-table__guide-cell{ text-align: right; }

.gbi-style-table__guide-link{
  display: inline-block;
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  border: 1px solid #f0ad4e;
  font-size: 0.8rem;
  text-decoration: none;
  white-space: nowrap;
}

.gbi-style-table__guide-link:hover,
.gbi-style-table__guide-link:focus{
  background: #f0ad4e;
  color: #fff;
}



/* =========================================================
   3) MOBILE — stacked rows, consistent labels, cleaner separators
   ========================================================= */

@media (max-width: 900px){

  /* Wrapper */
  .gbi-style-table-wrapper{
    width: calc(100% - 1.5rem);
    margin: 1rem auto;
  }

  /* Toolbar stacked */
  .gbi-style-table-wrapper .gbi-style-table-toolbar{
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 0.75rem 0.75rem 0.6rem;
  }

  /* Hide head, convert table to blocks */
  .gbi-style-table thead{ display: none; }

  .gbi-style-table,
  .gbi-style-table tbody,
  .gbi-style-table tr,
  .gbi-style-table td{
    display: block;
    width: 100%;
  }

  /* Each row becomes a “card row” */
  .gbi-style-table tr{
    margin: 0;
    background: #fff;
    border-top: none;
    border-bottom: 1px solid #eceff4;
  }

  /* Cell layout: label | value */
  body .gbi-style-table-wrapper .gbi-style-table td{
    display: grid !important;
    grid-template-columns: 90px 1fr !important;
    column-gap: 12px !important;
    align-items: center !important;
    padding: 0.45rem 0.9rem !important;
    border: none !important; /* we control borders at row level */
  }

  body .gbi-style-table-wrapper .gbi-style-table td::before{
    content: attr(data-label) !important;
    display: block !important;
    grid-column: 1 / 2 !important;
    grid-row: 1 / 2 !important;
    margin: 0 !important;
    padding: 0 !important;
    justify-self: start !important;
    align-self: center !important;
    text-align: left !important;
    font-size: 0.72rem !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: #88909e !important;
    white-space: nowrap !important;
  }

  body .gbi-style-table-wrapper .gbi-style-table td > *{
    grid-column: 2 / 3 !important;
    justify-self: start !important;
    min-width: 0 !important;
  }

  /* Guide aligns left on mobile */
  .gbi-style-table__guide-cell{ text-align: left; }
  .gbi-style-table td[data-label="Guide"] .gbi-style-table__guide-link{
    display: inline-flex;
    width: auto;
    max-width: max-content;
  }

  /* Disable desktop variant indent/branch marker */
  body .gbi-style-table-wrapper .gbi-style-table tbody tr[data-style-tier="variant"] td[data-label="Style"]{
    padding-left: 0.9rem !important; /* keep identical to other cells */
    position: static !important;
  }
  body .gbi-style-table-wrapper .gbi-style-table tbody tr[data-style-tier="variant"] td[data-label="Style"]::after{
    content: none !important;
  }

  /* STYLE cell: allow stacking of badge under name */
  .gbi-style-table td[data-label="Style"]{
    align-items: start !important;
    row-gap: 6px !important;
  }

  .gbi-style-table td[data-label="Style"] .gbi-style-table__style-link{
    display: inline-block;
    white-space: normal;
    line-height: 1.25;
  }

  .gbi-style-table td[data-label="Style"] .gbi-style-tier-badge{
    display: inline-block;
    margin-left: 0;
    padding: 6px 10px;
    border: 1px solid #cfd6df;
    border-radius: 999px;
    background: #fff;
    color: #111827;
    white-space: normal; /* allow wrap in pill */
    max-width: 100%;
  }

  .gbi-style-table td[data-label="Style"] .gbi-style-tier-badge .gbi-variant-parent-link{
    display: block;
    margin-top: 2px;
    white-space: normal;
  }

  /* Core rows: remove internal separators, keep only outer core boundary */
  body .gbi-style-table-wrapper .gbi-style-table tbody tr[data-style-tier="core"]{
    background: #f8fafc !important;
    border-top: 2px solid #d6d8dd !important;
    border-bottom: 2px solid #d6d8dd !important;
  }

  body .gbi-style-table-wrapper .gbi-style-table tbody tr[data-style-tier="core"]:first-child{
    border-top: 0 !important;
  }

  body .gbi-style-table-wrapper .gbi-style-table tbody tr[data-style-tier="core"] td{
    border-top: 0 !important;
    border-bottom: 0 !important;
  }

  /* Very narrow screens: smaller label column */
  @media (max-width: 380px){
    body .gbi-style-table-wrapper .gbi-style-table td{
      grid-template-columns: 78px 1fr !important;
    }
  }
}
