/* app/assets/stylesheets/tiers_groups.css */


/* ===================================
   Styling for _table.html.erb
   =================================== */

/* General table styling */

.tg-table {
  --col-handle:  2rem;
  --col-tier:    200px;
  --col-group:   140px;
  --col-group-label: 200px;
  --col-teams:   100px;
  --col-ranks:   180px;
  --col-actions: 100px;

  color: var(--ink);
  max-width: 100%;

  display: flex;
  flex-direction: column;

  gap: 0.5rem;
}

.tg-header {
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--line);
  padding-bottom: 0.5rem;
  margin-bottom: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
  color: var(--ink);
}

.tg-col--tier-drag       { display: flex; width: var(--col-handle);   flex-shrink: 0; justify-content: center; }
.tg-col--tier            { display: flex; width: var(--col-tier);     flex-shrink: 0; }
.tg-col--group-drag      { display: flex; width: var(--col-handle);   flex-shrink: 0; }
.tg-col--group           { display: flex; width: var(--col-group);       flex-shrink: 0; padding-left: 0.5rem; }
.tg-col--group-label     { display: flex; width: var(--col-group-label); flex-shrink: 0; align-items: center; gap: 0.35rem; padding-left: 0.5rem; overflow: hidden; }
.tg-col--teams           { display: flex; width: var(--col-teams);       flex-shrink: 0; padding-left: 0.5rem; }
.tg-col--ranks           { display: flex; width: var(--col-ranks);    flex-shrink: 0; padding-left: 0.5rem; flex: 1; }
.tg-col--group-delete    { display: flex; width: var(--col-handle);   flex-shrink: 0; }

.tg-header--tier {
  padding: 0 0.75rem;
}

#tiers_list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

/* Styling for "Add new" button row and form row */

.tg-add-tier__btn {
  display: flex;
  align-items: center;
  width: 100%;

  cursor: pointer;
  
  font-weight: 700;

  padding: 0.5rem;
  border-radius: 10px;
  border: 1.5px dashed var(--silver-light);
}

/* ===================================
   Styling for icons
   =================================== */

.tg-dropdown__icon,
.tg-add-tier__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  color: white;
  padding-bottom: 3px;
}
.tg-dropdown__icon--add {
  background: var(--green);
}
.tg-dropdown__icon--delete {
  background: var(--red);
}

.tg-add-tier__icon {
  background: var(--green);
  margin-right: 0.5rem;
}
/* Styling for "New Tier" row */

.tg-new-tier-row {
  display: flex;
  flex-direction: row;
  padding: 0.5rem;
}
.tg-input {
  /* padding: 0.5rem 1rem; */
  background-color: white;
  border: 1px solid var(--line);
  border-radius: 5px;
  padding: 0 0.5rem;
  flex: 1;
  width: 100%;
}

/* Confirm and Discard small buttons */

.tg-new-tier-row__actions {
  flex-shrink: 0;
  display: flex;
  gap: 0.5rem;
  align-items: center;
  margin: 0 1rem;
}

.tg-btn--icon {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0;
  transition: background 0.12s;
}

.tg-btn--confirm {
  background: var(--green);
  color: white;
  padding-bottom: 3px;
}

.tg-btn--discard {
  background: var(--ink-4);
  color: white;
}


/* ===================================
   Styling for _tier.html.erb
   =================================== */

.tg-new-tier-row,
.tg-tier {
  display: flex;
  align-items: flex-start;
  
  background: var(--bg-2);
  border-radius: 10px;
  border: 1px solid var(--line);
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  position: relative;
  transition: box-shadow 0.2s, opacity 0.2s;
  overflow: visible;
}

.tg-tier-columns {
  display: flex;
  align-items: center;
  flex-direction: row;
  padding: 0.5rem 0;
}

.tg-drag-handle {
  padding: 0.5rem;
  width: var(--col-handle);
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
/* Tier name cell */
.tg-tier-name {
  display: flex;
  flex: 1;
  flex-shrink: 0;

  align-items: center;

  padding: 0.5rem 0.75rem;
  gap: 0.5rem;

  border-radius: 99px;

  position: relative;
}

.tg-tier-name__field {
  font-weight: 700;
  flex: 1;
  min-width: 0;
}

.tg-tier-name__dropdown-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 5px;
  cursor: pointer;
  color: var(--bg-2);
  border-left: 1px solid var(--bg-2);
  /* color: white; */
}

/* Groups container */
.tg-group-columns {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
  padding: 0.25rem;
  justify-content: center;
  gap: 0.25rem;
}
/* ===================================
   Styling for _group.html.erb
   =================================== */

.tg-group {
  display: flex;
  align-items: center;
  min-height: 2rem;

  border-radius: 10px;
  border: 1px solid var(--line);

  padding: 0.25rem;

  background: white;

  /* transition: background 0.1s; */

  position: relative;
}

.tg-group__name,
.tg-group__teams {
  display: block;
  padding: 0.25rem 0.5rem;
  border-radius: 99px;
  cursor: text;
  transition: background 0.1s;
  flex-shrink: 0;
}

.tg-group__name { width: var(--col-group); }
.tg-group__teams { width: var(--col-teams); }

.tg-group__delete {
  width: 1.5rem;
  height: 1.5rem;
  border: none;
  border-radius: 50%;
  background: var(--red);
  color: white;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.1s;
  padding: 0 0.5rem 3px 0.5rem;
}

.tg-group:hover .tg-group__delete {
  opacity: 1;
}

.tg-hoverable:hover {
  background: var(--silver-light);
  cursor: pointer;
}

/* ===================================
   Shared dropdown row/list/search styling
   Used by bulk schedule (period/facility/location/template menus) and
   any other dropdowns built from the same building blocks.
   =================================== */

.tg-dropdown__search-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  border-bottom: 1px solid var(--line);
}

.tg-dropdown__search-input {
  flex: 1;
  padding: 0.25rem;
}

.tg-dropdown__search-input::placeholder {
  color: var(--ink-4);
}

.tg-dropdown__list {
  max-height: 250px;
  overflow-y: auto;
  padding: 0.25rem;
}

.tg-dropdown__location {
  display: flex;
  flex: 1;
  align-items: center;
  text-align: left;
  gap: 0.5rem;
  padding: 0.5rem;
  cursor: pointer;
  border-radius: 10px;
  transition: background 0.1s;
}

.tg-dropdown__location:hover {
  background: var(--silver-light);
}

.tg-dropdown__location--selected {
  font-weight: 700;
}

.tg-dropdown__location-row {
  display: flex;
  align-items: center;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
}

/* ===================================
   Dropdowns styling
   =================================== */

.tg-tier-name__dropdown-menu {
  top: calc(100% + 4px);
  left: 0;
  z-index: 10;
  min-width: 200px;
  
  position: absolute;
  display: flex;
  flex-direction: column;
  padding: 0.5rem;
  
  border: 1px solid var(--line);
  border-radius: 10px;
  background: white;
  box-shadow: 0 0.5rem 1.5rem rgba(0,0,0,0.1);
  overflow: hidden;
}

.tg-dropdown__item {
  display: flex;
  align-items: center;
  text-align: left;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem;
  cursor: pointer;
  border: none;
  transition: background 0.1s;
  font-weight: 700;
}

.tg-dropdown__item:hover    { background: var(--silver-light); }

/* ===================================
   Drag and drop styling
   =================================== */

/* Toolbar above the tier/group grid (Map Ranks button etc.) */
.tg-toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 1rem;
  margin-bottom: 0.75rem;
}

.tg-toolbar__stale-note {
  flex: 1 1 auto;
  margin: 0;
  font-size: 0.85rem;
  color: var(--warning, #b54708);
}

.tg-toolbar__map-ranks {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.tg-toolbar__map-ranks--stale {
  border-color: var(--warning, #b54708);
}

.tg-toolbar__warning-icon {
  color: var(--warning, #b54708);
  font-size: 1rem;
  line-height: 1;
}

/* ===================================
   Group Label column — colored pill + edit pencil on hover
   =================================== */

.tg-group__pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.85rem;
  border-radius: 999px;
  color: var(--ink);
  font-weight: 600;
  flex: 0 0 auto;
  transition: filter 0.1s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* Subtle whole-pill darken on row hover. */
.tg-group:hover .tg-group__pill {
  filter: brightness(0.95);
}

.tg-group__color-edit {
  background: transparent;
  border: none;
  padding: 0.15rem 0.3rem;
  border-radius: 4px;
  font-size: 0.85rem;
  line-height: 1;
  color: var(--ink-3);
  cursor: pointer;
  visibility: hidden;
  flex: 0 0 auto;
}

.tg-group__color-edit:hover {
  background: var(--bg-2);
  color: var(--ink);
}

/* Reveal the pencil on row hover so the surface stays calm at rest. */
.tg-group:hover .tg-group__color-edit {
  visibility: visible;
}

/* ===================================
   Color picker modal
   =================================== */

.tg-color-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 15, 12, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 500;
}

.tg-color-modal {
  background: var(--surface);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  width: min(440px, 92vw);
  padding: 1rem 1.25rem 1.25rem;
}

.tg-color-modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5rem;
}

.tg-color-modal__title {
  margin: 0;
  font-size: 1.1rem;
}

.tg-color-modal__group-name {
  font-weight: 500;
  color: var(--ink-3);
  margin-left: 0.25rem;
}

.tg-color-modal__close {
  background: transparent;
  border: none;
  color: var(--ink-3);
  font-size: 1.1rem;
  cursor: pointer;
}

.tg-color-modal__hint {
  font-size: 0.85rem;
  color: var(--ink-3);
  margin: 0 0 0.75rem;
}

.tg-color-modal__swatches {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.tg-color-modal__swatch {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  border: 1px solid var(--line);
  cursor: pointer;
  padding: 0;
}

.tg-color-modal__swatch:hover {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
}

.tg-color-modal__swatch.is-selected {
  outline: 3px solid var(--gold);
  outline-offset: 2px;
}

.tg-color-modal__custom {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.75rem;
}

.tg-color-modal__custom-label {
  font-size: 0.85rem;
  color: var(--ink-3);
}

/* Native <input type="color"> renders the OS picker — we just constrain the
   trigger swatch's size and remove the default chunky border. */
.tg-color-modal__custom-input {
  width: 3rem;
  height: 2rem;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  cursor: pointer;
  background: transparent;
}

.tg-color-modal__custom-input::-webkit-color-swatch-wrapper {
  padding: 2px;
  border-radius: 4px;
}

.tg-color-modal__custom-input::-webkit-color-swatch {
  border: none;
  border-radius: 4px;
}

.tg-color-modal__custom-input::-moz-color-swatch {
  border: none;
  border-radius: 4px;
}

.tg-color-modal__footer {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
}
