/**
 * @file
 * Custom ST theme styles for Gin admin theme.
 * Layout Builder customizations integrated with Gin's variable system.
 */

/* ==========================================================================
   Brand Colors
   ========================================================================== */

:root {
  --st-color-primary: #e5007c;
  --st-color-secondary: #c00;
  --st-color-accent: #e5007c;
  --st-color-white: #fff;
  --st-color-grey: #6a6a6a;
  --st-color-dark-grey: #484848;
  --st-color-black: #0f0f0f;
}

/* ==========================================================================
   Layout Builder Container
   ========================================================================== */

.layout-builder {
  background: var(--gin-bg-layer, #fff);
  border: 1px solid var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-m, 0.5rem);
  padding: var(--gin-spacing-l, 1.5rem);
}

.gin--dark-mode .layout-builder {
  background: var(--gin-bg-layer, #2a2a2d);
  border-color: var(--gin-border-color, #43454a);
}

/* ==========================================================================
   Layout Builder Section Controls
   ========================================================================== */

/* Increase spacing between the remove (×) button and the configure link
   to prevent accidental clicks on the wrong control. */
.layout-builder__link--remove {
  margin: 0 1.5rem 0.625rem -0.625rem !important;
}

/* ==========================================================================
   Layout Builder Sections
   ========================================================================== */

.layout-builder__section {
  background: var(--gin-bg-layer2, #edeff5);
  border: 1px solid var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-m, 0.5rem);
  padding: var(--gin-spacing-m, 1rem);
  margin-bottom: var(--gin-spacing-m, 1rem);
  overflow: hidden; /* Prevent section content from overflowing the layout container */
}

.gin--dark-mode .layout-builder__section {
  background: var(--gin-bg-layer2, #3b3b3f);
  border-color: var(--gin-border-color, #43454a);
}

/* ==========================================================================
   Add Section Area
   ========================================================================== */

.layout-builder__add-section {
  box-sizing: border-box; /* Prevent overflow from width:100% + border + padding */
  background: transparent;
  border: 2px dashed var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-m, 0.5rem);
  padding: var(--gin-spacing-m, 1rem);
  margin: var(--gin-spacing-s, 0.5rem) 0;
  text-align: center;
  outline: none;
}

.layout-builder__add-section:hover {
  border-color: var(--st-color-primary);
  background: var(--gin-bg-layer2, #edeff5);
}

.gin--dark-mode .layout-builder__add-section {
  border-color: var(--gin-border-color, #43454a);
}

.gin--dark-mode .layout-builder__add-section:hover {
  border-color: var(--st-color-primary);
  background: var(--gin-bg-layer2, #3b3b3f);
}

/* ==========================================================================
   Layout Builder Regions
   ========================================================================== */

/* Ensure multi-column layouts display correctly */
.layout--twocol-section,
.layout--threecol-section {
  display: flex !important;
  flex-wrap: wrap;
}

.layout--twocol-section > .layout__region,
.layout--threecol-section > .layout__region {
  min-width: 0; /* Prevent flex items from overflowing */
  box-sizing: border-box;
}

/* Region styling */
.layout-builder__region,
.layout__region {
  min-height: 50px;
  padding: var(--gin-spacing-xs, 0.25rem);
}

.gin--dark-mode .layout-builder__region,
.gin--dark-mode .layout__region {
  /* Keep regions transparent in dark mode */
}

/* Region labels */
.layout-builder__region-label {
  color: var(--gin-color-text-light, #545560);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.gin--dark-mode .layout-builder__region-label {
  color: var(--gin-color-text-light, #9e9fa0);
}

/* ==========================================================================
   Layout Builder Blocks
   ========================================================================== */

.layout-builder-block {
  background: var(--gin-bg-layer, #fff);
  border: 1px solid var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-m, 0.5rem);
  padding: var(--gin-spacing-m, 1rem);
  margin-bottom: var(--gin-spacing-s, 0.5rem);
  cursor: move;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.layout-builder-block:hover {
  border-color: var(--st-color-primary);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.gin--dark-mode .layout-builder-block {
  background: var(--gin-bg-layer3, #47474c);
  border-color: var(--gin-border-color, #43454a);
}

.gin--dark-mode .layout-builder-block:hover {
  border-color: var(--st-color-primary);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* Block type label - compact chip */
.layout-builder-block::before {
  content: attr(data-layout-block-uuid);
  display: none;
}

/* Block labels via data attribute */
.layout-builder__section .block[data-block-type]::before {
  content: attr(data-block-type);
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--st-color-primary);
  background: rgba(229, 0, 124, 0.08);
  padding: 3px 8px;
  margin-bottom: 8px;
  border-left: 2px solid var(--st-color-primary);
  border-radius: 0 3px 3px 0;
}

.gin--dark-mode .layout-builder__section .block[data-block-type]::before {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  border-left-color: var(--st-color-primary);
}

/* Block content text colors */
.layout-builder-block,
.layout-builder-block .field__item {
  color: var(--gin-color-text, #222330);
}

.layout-builder-block .field__label {
  color: var(--gin-color-text-light, #545560);
}

.gin--dark-mode .layout-builder-block,
.gin--dark-mode .layout-builder-block .field__item {
  color: var(--gin-color-text, #d2d3d3);
}

.gin--dark-mode .layout-builder-block .field__label {
  color: var(--gin-color-text-light, #9e9fa0);
}

/* ==========================================================================
   Add Block Area
   ========================================================================== */

.layout-builder__add-block {
  background: transparent;
  border: 2px dashed var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-m, 0.5rem);
  padding: var(--gin-spacing-s, 0.5rem);
  margin: var(--gin-spacing-xs, 0.25rem) 0;
  text-align: center;
}

.layout-builder__add-block:hover {
  border-color: var(--st-color-primary);
  background: var(--gin-bg-layer2, #edeff5);
}

.gin--dark-mode .layout-builder__add-block {
  border-color: var(--gin-border-color, #43454a);
}

.gin--dark-mode .layout-builder__add-block:hover {
  border-color: var(--st-color-primary);
  background: var(--gin-bg-layer2, #3b3b3f);
}

/* ==========================================================================
   Action Links
   ========================================================================== */

.layout-builder__link {
  color: var(--gin-color-text, #222330);
  text-decoration: none;
  transition: color 0.15s ease;
}

.layout-builder__link:hover {
  color: var(--st-color-primary);
}

.gin--dark-mode .layout-builder__link {
  color: var(--gin-color-text, #d2d3d3);
}

.gin--dark-mode .layout-builder__link:hover {
  color: var(--st-color-primary);
}

/* Add links */
.layout-builder__link--add {
  color: var(--st-color-primary);
  font-weight: 500;
}

.layout-builder__link--add:hover {
  color: var(--st-color-secondary, #c00);
}

.gin--dark-mode .layout-builder__link--add {
  color: var(--st-color-primary);
}

/* ==========================================================================
   Interactive States
   ========================================================================== */

/* Highlighted state */
.is-layout-builder-highlighted {
  outline: 2px solid var(--st-color-primary) !important;
  outline-offset: 2px;
}

/* Dragging state */
.ui-sortable-helper {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2) !important;
  opacity: 0.95;
  z-index: 1000;
}

.gin--dark-mode .ui-sortable-helper {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5) !important;
}

/* Drop placeholder */
.ui-sortable-placeholder {
  background: rgba(229, 0, 124, 0.1) !important;
  border: 2px dashed var(--st-color-primary) !important;
  border-radius: var(--gin-border-m, 0.5rem);
  visibility: visible !important;
}

/* Drop target region */
.layout-builder__region.ui-sortable-over {
  background: rgba(229, 0, 124, 0.05);
}

/* ==========================================================================
   Off-Canvas Dialog
   ========================================================================== */

.ui-dialog.ui-dialog-off-canvas {
  background: var(--gin-bg-layer, #fff);
}

.gin--dark-mode .ui-dialog.ui-dialog-off-canvas {
  background: #2a2a2a;
}

.gin--dark-mode #drupal-off-canvas {
  color: #fff;
}

/* Layout selection list */
#drupal-off-canvas .layout-selection {
  list-style: none;
  padding: 0;
  margin: 0;
}

#drupal-off-canvas .layout-selection__item {
  border-bottom: 1px solid var(--gin-border-color, #d4d4d8);
}

.gin--dark-mode #drupal-off-canvas .layout-selection__item {
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

#drupal-off-canvas .layout-selection__item-link {
  display: block;
  padding: 12px;
  color: var(--gin-color-text, #222330);
  text-decoration: none;
  transition: background-color 0.15s ease;
}

#drupal-off-canvas .layout-selection__item-link:hover {
  background: var(--gin-bg-layer2, #edeff5);
}

.gin--dark-mode #drupal-off-canvas .layout-selection__item-link {
  color: #fff;
}

.gin--dark-mode #drupal-off-canvas .layout-selection__item-link:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* Block categories in off-canvas */
#drupal-off-canvas .inline-block-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#drupal-off-canvas .inline-block-list__item {
  border-bottom: 1px solid var(--gin-border-color, #d4d4d8);
}

.gin--dark-mode #drupal-off-canvas .inline-block-list__item {
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

#drupal-off-canvas .inline-block-list__item a {
  display: block;
  padding: 10px 12px;
  color: var(--gin-color-text, #222330);
  text-decoration: none;
}

#drupal-off-canvas .inline-block-list__item a:hover {
  background: var(--gin-bg-layer2, #edeff5);
  color: var(--st-color-primary);
}

.gin--dark-mode #drupal-off-canvas .inline-block-list__item a {
  color: #fff;
}

.gin--dark-mode #drupal-off-canvas .inline-block-list__item a:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* ==========================================================================
   Layout Builder Form Wrapper
   ========================================================================== */

.gin-layout-builder-wrapper {
  margin-bottom: var(--gin-spacing-l, 1.5rem);
}

.gin-layout-builder-wrapper.claro-details {
  background: transparent;
  border: 1px solid var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-m, 0.5rem);
}

.gin--dark-mode .gin-layout-builder-wrapper.claro-details {
  border-color: var(--gin-border-color, #43454a);
}

.gin-layout-builder-wrapper .claro-details__summary {
  color: var(--gin-color-title, #222330);
  font-weight: 600;
}

.gin--dark-mode .gin-layout-builder-wrapper .claro-details__summary {
  color: var(--gin-color-title, #fff);
}

.gin-layout-builder-wrapper .claro-details__wrapper {
  color: var(--gin-color-text, #222330);
}

.gin--dark-mode .gin-layout-builder-wrapper .claro-details__wrapper {
  color: var(--gin-color-text, #d2d3d3);
}

/* Form elements */
.gin-layout-builder-wrapper .form-item__label,
.gin-layout-builder-wrapper label {
  color: var(--gin-color-text, #222330);
}

.gin--dark-mode .gin-layout-builder-wrapper .form-item__label,
.gin--dark-mode .gin-layout-builder-wrapper label {
  color: var(--gin-color-text, #d2d3d3);
}

.gin-layout-builder-wrapper .form-select,
.gin-layout-builder-wrapper select {
  background: var(--gin-bg-layer, #fff);
  color: var(--gin-color-text, #222330);
  border: 1px solid var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-s, 0.25rem);
}

.gin--dark-mode .gin-layout-builder-wrapper .form-select,
.gin--dark-mode .gin-layout-builder-wrapper select {
  background: var(--gin-bg-layer3, #47474c);
  color: #fff;
  border-color: var(--gin-border-color, #43454a);
}

/* Buttons */
.gin-layout-builder-wrapper .button {
  background: var(--gin-bg-layer, #fff);
  color: var(--gin-color-text, #222330);
  border: 1px solid var(--gin-border-color, #d4d4d8);
  border-radius: var(--gin-border-s, 0.25rem);
  transition: border-color 0.15s ease, color 0.15s ease;
}

.gin-layout-builder-wrapper .button:hover {
  border-color: var(--st-color-primary);
  color: var(--st-color-primary);
}

.gin--dark-mode .gin-layout-builder-wrapper .button {
  background: var(--gin-bg-layer3, #47474c);
  color: #fff;
  border-color: var(--gin-border-color, #43454a);
}

.gin--dark-mode .gin-layout-builder-wrapper .button:hover {
  border-color: var(--st-color-primary);
  color: var(--st-color-primary);
}

/* Required mark */
.gin-layout-builder-wrapper .required-mark {
  color: var(--st-color-primary);
}

/* Call to action spacing */
.gin-layout-builder-wrapper .call-to-action {
  margin: var(--gin-spacing-m, 1rem) 0;
}

/* ==========================================================================
   Headings in Layout Builder
   ========================================================================== */

.layout-builder-block h1,
.layout-builder-block h2,
.layout-builder-block h3,
.layout-builder-block h4,
.layout-builder-block h5,
.layout-builder-block h6 {
  color: var(--gin-color-title, #222330);
  font-weight: 400;
}

.gin--dark-mode .layout-builder-block h1,
.gin--dark-mode .layout-builder-block h2,
.gin--dark-mode .layout-builder-block h3,
.gin--dark-mode .layout-builder-block h4,
.gin--dark-mode .layout-builder-block h5,
.gin--dark-mode .layout-builder-block h6 {
  color: var(--gin-color-title, #fff);
}
