/* =========================================
   20-PAGES / LOCATION LIST
   - Grey location list frame
   - Table structure (borders/collapse)
   - Location block classes
   - Print stylesheet
   ========================================= */
@layer pages {

  /* =========================================
     Grey Location List Styles (frame & blocks)
     ========================================= */
  #page-background {
    background-color: var(--clr-berry-900);
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }

  .gl-location-box {
    background-color: var(--clr-white);
    color: var(--clr-black);
    border: 1px solid var(--clr-black);
    border-radius: var(--comp-radius);
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
    font-size: var(--fs-sm-s);
    width: 680px;
    max-width: calc(100% - 4rem);
    margin: 5px auto;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 50px;
    padding-right: 50px;
  }

  .gl-location-box table {
    font-size: var(--fs-sm-s);
    border: 1px solid var(--clr-black);
    border-collapse: collapse;
  }

  .gl-location-box thead tr {
    background-color: var(--clr-table-header);
    text-align: center;
  }

  .gl-location-box th { font-weight: 700; }

  .gl-location-box td,
  .gl-location-box th,
  .gl-location-box tr,
  .gl-location-box a {
    color: var(--clr-black);
  }

  .gl-location-box td {
    text-align: left;
    border: 1px solid var(--clr-black);
    padding: 6px;
  }

  /* Make the seam between rows a single line */
  .gl-location-box td { border-top: 0; }
  .gl-location-box tbody tr:first-child td { border-top: 1px solid var(--clr-black); }

  /* ── Block & section headings ── */
  .gl-block-heading {
    background-color: var(--clr-alert-bg);
    margin-bottom: 0;
    font-size: var(--fs-md-s);
    font-weight: 700;
    text-align: center;
    border: 1px solid var(--clr-black);
    border-bottom: none;
  }

  .gl-main-heading {
    background-color: var(--clr-info-bg);
    border: 1px solid var(--clr-black);
    color: var(--clr-black);
    text-align: center;
    font-weight: 700;
    padding: 6px;
    border-bottom: none;
  }

  /* ── Production office header ── */
  .gl-office-header {
    font-weight: 700;
    background-color: var(--clr-table-header);
    text-align: center;
  }

  .gl-office-address {
    text-align: left;
  }

  /* ── Production office contact cells ── */
  .gl-office-contact-name   { width: 30%; }
  .gl-office-contact-pos    { width: 20%; border-left: none; border-right: none; }
  .gl-office-contact-mobile { width: 25%; border-left: none; border-right: none; }
  .gl-office-contact-email  { width: 25%; }

  /* ── Location block tables ── */
  .gl-location-table {
    width: 100%;
    font-size: var(--fs-md-s);
    border-collapse: collapse;
    margin-bottom: 0;
    border-bottom: none !important;
  }

  .gl-location-name {
    font-weight: 700;
    text-transform: uppercase;
    background-color: #e0e0e0;
  }

  .gl-location-box .gl-location-name {
    text-align: center !important;
  }

  .gl-address-cell {
    width: 75%;
    vertical-align: top;
    border-bottom: none !important;
  }

  .gl-address-cell strong { text-transform: uppercase; }

  .gl-links-cell {
    width: 25%;
    vertical-align: top;
    border-bottom: none !important;
  }

  /* ── Contact table ── */
  .gl-contact-table {
    width: 100%;
    font-size: var(--fs-md-s);
    border-collapse: collapse;
    margin-bottom: 10px;
    border-top: 1px solid var(--clr-black) !important;
  }

  /* Remove top border from first contact row to prevent double border */
  .gl-contact-table tr:first-child td { border-top: none; }

  /* Remove vertical dividers between contact columns */
  .gl-contact-table td {
    border-left: none;
    border-right: none;
  }

  .gl-contact-name     { width: 20%; border-left: 1px solid var(--clr-black); }
  .gl-contact-position { width: 20%; }
  .gl-contact-mobile   { width: 17%; }
  .gl-contact-phone2   { color: var(--clr-black); font-size: var(--fs-base-s); padding: 3px 5px; width: 17%; }
  .gl-contact-email    { width: 26%; border-right: 1px solid var(--clr-black); }

  .gl-email-link {
    color: var(--clr-info) !important;
    text-decoration: underline;
  }

  .gl-email-link:hover {
    color: var(--clr-info-dark) !important;
  }

  .gl-map-link {
    color: var(--clr-info) !important;
    text-decoration: underline;
  }

  .gl-map-link:hover {
    color: var(--clr-info-dark) !important;
  }

  .gl-no-contacts {
    padding: 6px 5px;
    font-style: italic;
    font-size: var(--fs-base-s);
    background-color: var(--clr-warning-subtle);
    color: #7c6200;
    border-left: 3px solid var(--clr-warning);
  }

  /* ── Empty block & setup banner ── */
  .gl-empty-block {
    padding: 12px 16px;
    font-style: italic;
    color: var(--gray-600);
    font-size: var(--fs-md-s);
    border: 1px dashed var(--gray-300);
    margin: 8px 0 16px 0;
    border-radius: var(--comp-radius);
  }

  .gl-setup-banner {
    background: var(--clr-warning-subtle);
    border: 1px solid var(--clr-warning);
    border-radius: 6px;
    padding: 10px 16px;
    font-size: var(--fs-lg-s);
    color: #5d4037;
    margin-bottom: 16px;
  }

  .gl-setup-banner a {
    color: var(--clr-warning-dark);
    font-weight: 600;
    text-decoration: underline;
  }

  /* ── Printable table (generic) ── */
  table.table {
    width: 100%;
    font-size: var(--fs-base-s);
    border-collapse: collapse;
  }
  table.table td {
    padding: 4px;
    border: 1px solid var(--gray-350);
  }

  .gl-office-table td,
  .gl-office-table th {
    border: 1px solid var(--clr-black) !important;
    color: var(--clr-black);
  }

  .gl-office-table {
    border: 1px solid var(--clr-black) !important;
  }

  /* ── Edit button on location name ── */
  .gl-location-name {
    position: relative;
  }

  .gl-loc-name-text {
    display: inline-block;
    width: calc(100% - 30px);
    text-align: center;
  }

  .gl-edit-loc-btn {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(var(--clr-berry-500-rgb),0.08);
    border: 1px solid rgba(var(--clr-berry-500-rgb),0.25);
    border-radius: var(--comp-radius-sm);
    color: var(--clr-berry-500);
    font-size: var(--fs-xs-s);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 2px 6px;
    cursor: pointer;
    line-height: 1.4;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
  }

  .gl-edit-loc-btn:hover {
    background: rgba(var(--clr-berry-500-rgb),0.15);
    border-color: var(--clr-berry-400);
    color: var(--clr-berry-400);
  }

  /* Title — replaced by .doc-page-header in 30-documents.css */

  /* ── Empty scripted location note ── */
  .gl-no-scripted-note {
    font-style: italic;
    font-weight: 400;
    font-size: var(--fs-base-s);
    color: #7c6200;
    text-transform: none;
    letter-spacing: 0;
    background-color: var(--clr-warning-subtle);
    border-left: 3px solid var(--clr-warning);
    padding: 6px 5px;
    display: block;
    width: 100%;
    box-sizing: border-box;
  }


  /* GL modal rules extracted to 20-locList-modal.css */

  /* Contact List + Address List rules extracted to 20-locList-address.css */

  /* ── Print styles ── */
  @media print {
    body * { visibility: hidden; }
    #location-list, #location-list * { visibility: visible; }
    #location-list {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
    }
  }

  /* ════════════════════════════════════════════════════════════
     LOCATIONS & UNIT BASES RESTYLE — loc-* / ub-* classes
     Added 2026-03-15.  Do NOT modify .gl-* rules above.
     ════════════════════════════════════════════════════════════ */

  /* Page background wrappers removed — .sb-page handles layout */

  .loc-block-col,
  .ub-block-col {
    margin-bottom: 16px;
  }

  /* ══════════════════════════════════════
     SECTION 2 — Block phase dividers
     ══════════════════════════════════════ */

  .loc-phase-divider,
  .ub-phase-divider {
    font-size: var(--fs-base-s);
    font-weight: 700;
    padding: 5px 12px;
    border-radius: var(--comp-radius-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 8px;
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .loc-phase-divider-blue,
  .ub-phase-divider-blue {
    background: rgba(70, 130, 220, 0.14);
    color: var(--clr-info-light);
    border-bottom: 1px solid rgba(70, 130, 220, 0.25);
  }

  .loc-phase-divider-grey,
  .ub-phase-divider-grey {
    background: rgba(140, 140, 140, 0.12);
    color: var(--text-muted);
    border-bottom: 1px solid rgba(140, 140, 140, 0.2);
  }

  .loc-phase-count {
    font-size: var(--fs-sm-s);
    font-weight: 400;
    opacity: 0.65;
  }

  /* ══════════════════════════════════════
     SECTION 3 — Record accordion
     ══════════════════════════════════════ */

  .loc-accordion,
  .ub-accordion {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .loc-accordion-item,
  .ub-accordion-item {
    border-radius: var(--comp-radius-sm);
    overflow: visible;
  }

  .loc-accordion-header,
  .ub-accordion-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--clr-berry-700, #4a1228);
    border-left: 3px solid transparent;
    border-radius: var(--comp-radius-sm);
    font-size: var(--fs-md-s);
    font-weight: 600;
    cursor: pointer;
    user-select: none;
    transition: background 0.15s;
  }

  .loc-accordion-header:hover,
  .ub-accordion-header:hover {
    background: var(--clr-berry-600, #6d1b3d);
  }

  .loc-accordion-header.open,
  .ub-accordion-header.open {
    border-left-color: var(--clr-berry-400, #c4226e);
    background: var(--clr-berry-800, #2e0c1a);
    border-radius: 3px 3px 0 0;
  }

  .loc-chevron,
  .ub-chevron {
    flex: 0 0 14px;
    font-size: var(--fs-sm-s);
    transition: transform 0.2s;
    color: var(--white-a50);
  }

  .loc-accordion-header.open .loc-chevron,
  .ub-accordion-header.open .ub-chevron {
    transform: rotate(90deg);
  }

  .loc-header-name,
  .ub-header-name {
    flex: 0 0 200px;
    font-weight: 700;
    color: var(--clr-white);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .loc-header-sub,
  .ub-header-sub {
    flex: 1;
    color: var(--white-a55);
    font-weight: 400;
    font-size: var(--fs-base-s);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .loc-header-status {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
  }

  .loc-header-status .status {
    font-size: var(--fs-md-s);
    opacity: 0.85;
  }

  .loc-header-check,
  .ub-header-check {
    flex: 0 0 auto;
    margin-right: 4px;
  }

  .loc-accordion-body,
  .ub-accordion-body {
    display: none;
    background: var(--white-a03);
    border: 1px solid var(--white-a06);
    border-top: none;
    border-radius: 0 0 3px 3px;
    padding: 12px 16px 16px;
    content-visibility: auto;
    contain-intrinsic-size: 0 500px;
  }

  .loc-accordion-body.open,
  .ub-accordion-body.open {
    display: block;
  }

  /* ══════════════════════════════════════
     SECTION 4 — Always-visible top fields
     ══════════════════════════════════════ */

  .loc-top-grid,
  .ub-top-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
    margin-bottom: 12px;
  }

  @media (max-width: 900px) {
    .loc-top-grid,
    .ub-top-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media (max-width: 480px) {
    .loc-top-grid,
    .ub-top-grid {
      grid-template-columns: 1fr;
    }
  }

  .loc-top-field,
  .ub-top-field {
    display: flex;
    flex-direction: column;
    gap: 3px;
  }

  .loc-top-label,
  .ub-top-label {
    font-size: var(--label-font);
    font-weight: 600;
    text-transform: var(--label-transform);
    letter-spacing: 0.4px;
    color: var(--text-placeholder);
  }

  .loc-addr-contact-row,
  .ub-addr-contact-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 12px;
  }

  @media (max-width: 700px) {
    .loc-addr-contact-row,
    .ub-addr-contact-row {
      grid-template-columns: 1fr;
    }
  }

  .loc-addr-block,
  .ub-addr-block {
    display: flex;
    flex-direction: column;
    gap: 5px;
  }

  .loc-body-section-title,
  .ub-body-section-title {
    font-size: var(--label-font);
    font-weight: var(--label-weight);
    text-transform: var(--label-transform);
    letter-spacing: var(--label-spacing);
    color: var(--white-a30);
    margin-bottom: 6px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--white-a06);
  }

  /* ══════════════════════════════════════
     SECTION 5 — Sub-group accordions
     ══════════════════════════════════════ */

  /* Record-level tab bar (replaces sub-accordions) */
  .sb-tab-bar,
  .ub-record-tabs {
    margin-top: 8px;
    padding: 0 8px;
    border-bottom: 0.5px solid var(--white-a08);
    border-top: 0.5px solid var(--white-a08);
  }
  .sb-tab-bar .sb-tab,
  .ub-record-tabs .sb-tab {
    font-size: var(--fs-sm-s);
    padding: 6px 10px;
  }
  .sb-tab-pane,
  .ub-tab-pane {
    display: none;
    padding: 8px;
  }
  .sb-tab-pane.active,
  .ub-tab-pane.active {
    display: block;
  }
  .loc-gallery-toolbar,
  .ub-gallery-toolbar {
    display: flex;
    align-items: center;
    gap: var(--toolbar-gap);
    margin-bottom: 6px;
  }
  .loc-mo-toolbar {
    display: flex;
    align-items: center;
    gap: var(--toolbar-gap);
    margin-bottom: 6px;
  }

  /* Legacy subgroup rules (kept for any remaining references) */
  .loc-subgroup-list,
  .ub-subgroup-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: 8px;
  }

  .loc-subgroup-item,
  .ub-subgroup-item {
    border-radius: var(--comp-radius-sm);
  }

  .loc-subgroup-header,
  .ub-subgroup-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: var(--white-a04);
    border-left: 3px solid transparent;
    border-radius: var(--comp-radius-sm);
    font-size: var(--fs-base-s);
    font-weight: 600;
    color: var(--white-a65);
    cursor: pointer;
    user-select: none;
    transition: background 0.15s, color 0.15s;
    text-transform: uppercase;
    letter-spacing: 0.4px;
  }

  .loc-subgroup-header:hover,
  .ub-subgroup-header:hover {
    background: var(--white-a07);
    color: var(--white-a85);
  }

  .loc-subgroup-header.open,
  .ub-subgroup-header.open {
    border-left-color: var(--clr-berry-400, #c4226e);
    background: rgba(var(--clr-berry-500-rgb),0.12);
    color: var(--clr-white);
    border-radius: 3px 3px 0 0;
  }

  .loc-sub-chevron,
  .ub-sub-chevron {
    flex: 0 0 12px;
    font-size: var(--fs-xs-s);
    transition: transform 0.2s;
    color: var(--white-a30);
  }

  .loc-subgroup-header.open .loc-sub-chevron,
  .ub-subgroup-header.open .ub-sub-chevron {
    transform: rotate(90deg);
  }

  .loc-subgroup-body,
  .ub-subgroup-body {
    display: none;
    padding: 10px 12px 12px;
    background: var(--white-a02);
    border: 1px solid var(--white-a05);
    border-top: none;
    border-radius: 0 0 3px 3px;
  }

  .loc-subgroup-body.open,
  .ub-subgroup-body.open {
    display: block;
  }

  /* ══════════════════════════════════════
     SECTION 6 — Direct input fields
     ══════════════════════════════════════ */

  .fm-field,
  .ub-field {
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin-bottom: 8px;
  }

  .loc-field-label,
  .ub-field-label {
    font-size: var(--label-font);
    font-weight: 600;
    text-transform: var(--label-transform);
    letter-spacing: 0.4px;
    color: var(--text-placeholder);
  }

  /* loc-input / ub-input → fm-input (24-forms.css) */

  .loc-field-row,
  .ub-field-row {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 8px;
    align-items: center;
    margin-bottom: 6px;
  }

  .loc-field-row .loc-field-label,
  .ub-field-row .ub-field-label {
    text-align: right;
    padding-right: 4px;
  }

  .loc-field-grid-2,
  .ub-field-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .loc-field-grid-3,
  .ub-field-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }

  @media (max-width: 700px) {
    .loc-field-grid-2,
    .ub-field-grid-2,
    .loc-field-grid-3,
    .ub-field-grid-3 {
      grid-template-columns: 1fr;
    }
  }

  /* ══════════════════════════════════════
     SECTION 7 — Record-level save bar
     ══════════════════════════════════════ */

  .fm-save-bar,
  .ub-save-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 0 2px;
    margin-top: 12px;
    border-top: 1px solid var(--white-a07);
  }

  .loc-save-status,
  .ub-save-status {
    font-size: var(--fs-sm-s);
    color: var(--text-placeholder);
    flex: 1;
  }

  .loc-save-status.dirty,
  .ub-save-status.dirty {
    color: rgba(255,200,80,0.8);
  }

  .loc-save-status.saved,
  .ub-save-status.saved {
    color: rgba(80,200,120,0.8);
  }

  .loc-save-btn,
  .ub-save-btn {
    font-size: var(--fs-base-s);
    padding: 4px 14px;
    background: rgba(var(--clr-berry-500-rgb),0.25);
    border: 1px solid rgba(var(--clr-berry-500-rgb),0.5);
    border-radius: var(--comp-radius-sm);
    color: var(--clr-white);
    cursor: pointer;
    transition: background 0.15s;
  }

  .loc-save-btn:hover,
  .ub-save-btn:hover {
    background: rgba(var(--clr-berry-500-rgb),0.45);
  }

  .loc-save-btn.is-dirty,
  .ub-save-btn.is-dirty {
    background: var(--clr-berry-500, #9e1a5e);
    border-color: var(--clr-berry-400, #c4226e);
    animation: loc-pulse 1.8s ease-in-out infinite;
  }

  @keyframes loc-pulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.75; }
  }

  .loc-delete-btn,
  .ub-delete-btn {
    font-size: var(--fs-base-s);
    padding: 1px;
    background: transparent;
    border: 1px solid rgba(220,60,50,0.3);
    border-radius: 3px;
    color: rgba(220,60,50,0.55);
    cursor: pointer;
    transition: all 0.15s;
    margin-left: auto;
  }

  .loc-delete-btn:hover,
  .ub-delete-btn:hover {
    background: rgba(239,68,68,0.12);
    border-color: var(--clr-danger);
    color: var(--clr-danger);
  }

  /* ══════════════════════════════════════
     SECTION 8 — Contacts (fm-* restyled)
     ══════════════════════════════════════ */

  /* Accordion contact rows override base grid (24-forms.css) with flex for narrow accordion context */
  .loc-accordion-body .fm-contact-row,
  .ub-accordion-body .fm-contact-row {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
    padding: 4px 0;
    border-bottom: var(--tr-border);
  }

  .loc-accordion-body .fm-contact-input,
  .ub-accordion-body .fm-contact-input {
    background: var(--white-a04);
    border-radius: var(--comp-radius-sm);
    color: var(--white-a85);
    font-size: var(--fs-base-s);
    padding: 4px 7px;
    flex: 1;
    min-width: 80px;
  }

  .loc-accordion-body .fm-contact-input:focus,
  .ub-accordion-body .fm-contact-input:focus {
    outline: var(--focus-outline);
    border-color: var(--clr-berry-400);
    background: var(--white-a07);
  }

  .loc-accordion-body .fm-contact-remove,
  .ub-accordion-body .fm-contact-remove {
    background: transparent;
    border: none;
    color: rgba(220,60,50,0.5);
    cursor: pointer;
    padding: 2px 4px;
    font-size: var(--fs-md-s);
    transition: color 0.15s;
  }

  .loc-accordion-body .fm-contact-remove:hover,
  .ub-accordion-body .fm-contact-remove:hover {
    color: var(--clr-danger);
  }

  .loc-accordion-body .fm-add-contact-btn,
  .ub-accordion-body .fm-add-contact-btn {
    font-size: var(--fs-base-s);
    padding: 3px 10px;
    background: rgba(var(--clr-berry-500-rgb),0.15);
    border: 1px dashed rgba(var(--clr-berry-500-rgb),0.35);
    border-radius: var(--comp-radius-sm);
    color: var(--white-a60);
    cursor: pointer;
    margin-top: 4px;
    transition: all 0.15s;
  }

  .loc-accordion-body .fm-add-contact-btn:hover,
  .ub-accordion-body .fm-add-contact-btn:hover {
    background: rgba(var(--clr-berry-500-rgb),0.28);
    color: var(--clr-white);
  }

  /* Extends base .fm-save-bar (24-forms.css) — always visible, smaller gap for accordion context */
  .loc-accordion-body .fm-save-bar,
  .ub-accordion-body .fm-save-bar {
    display: flex;
    gap: 6px;
    margin-top: 6px;
  }

  /* Override base .fm-btn-save (24-forms.css) — smaller padding/font for accordion context */
  .loc-accordion-body .fm-btn-save,
  .ub-accordion-body .fm-btn-save {
    font-size: var(--fs-base-s);
    padding: 3px 12px;
    background: rgba(var(--clr-berry-500-rgb),0.25);
    border: 1px solid rgba(var(--clr-berry-500-rgb),0.5);
    border-radius: var(--comp-radius-sm);
    color: var(--clr-white);
    cursor: pointer;
  }

  .loc-accordion-body .fm-btn-cancel,
  .ub-accordion-body .fm-btn-cancel {
    font-size: var(--fs-base-s);
    padding: 3px 10px;
    background: transparent;
    border: 1px solid var(--white-a15);
    border-radius: var(--comp-radius-sm);
    color: var(--white-a50);
    cursor: pointer;
  }

  /* ══════════════════════════════════════
     SECTION 9 — Tri-state badges
     ══════════════════════════════════════ */

  /* (ls-badge rules removed — replaced by ls-cycle-pill) */

  /* ══════════════════════════════════════
     SECTION 10 — Flash / feedback
     ══════════════════════════════════════ */

  @keyframes loc-save-flash {
    0%   { background: rgba(var(--clr-berry-500-rgb),0.35); }
    100% { background: transparent; }
  }

  .loc-accordion-item.save-flash,
  .ub-accordion-item.save-flash {
    animation: loc-save-flash 0.9s ease-out forwards;
  }

  /* ══════════════════════════════════════
     Tag toolbar buttons inside dark
     sub-group bodies
     ══════════════════════════════════════ */
  .loc-subgroup-body .tag-btn.btn-outline-success,
  .ub-subgroup-body .tag-btn.btn-outline-success {
    color: var(--clr-success);
    border-color: var(--clr-success);
  }
  .loc-subgroup-body .tag-btn.btn-outline-success:hover,
  .loc-subgroup-body .tag-btn.btn-outline-success.active,
  .ub-subgroup-body .tag-btn.btn-outline-success:hover,
  .ub-subgroup-body .tag-btn.btn-outline-success.active {
    background: rgba(94,192,106,0.2);
    color: var(--clr-success);
  }

  .loc-subgroup-body .tag-btn.btn-outline-primary,
  .ub-subgroup-body .tag-btn.btn-outline-primary {
    color: var(--clr-info-light);
    border-color: var(--clr-info-light);
  }
  .loc-subgroup-body .tag-btn.btn-outline-primary:hover,
  .loc-subgroup-body .tag-btn.btn-outline-primary.active,
  .ub-subgroup-body .tag-btn.btn-outline-primary:hover,
  .ub-subgroup-body .tag-btn.btn-outline-primary.active {
    background: rgba(106,173,235,0.2);
    color: var(--clr-info-light);
  }

  .loc-subgroup-body .tag-btn.btn-outline-warning,
  .ub-subgroup-body .tag-btn.btn-outline-warning {
    color: var(--clr-attn);
    border-color: var(--clr-attn);
  }
  .loc-subgroup-body .tag-btn.btn-outline-warning:hover,
  .loc-subgroup-body .tag-btn.btn-outline-warning.active,
  .ub-subgroup-body .tag-btn.btn-outline-warning:hover,
  .ub-subgroup-body .tag-btn.btn-outline-warning.active {
    background: rgba(255,210,80,0.2);
    color: var(--clr-attn);
  }

  .loc-subgroup-body .tag-btn.btn-outline-danger,
  .ub-subgroup-body .tag-btn.btn-outline-danger {
    color: var(--clr-danger);
    border-color: var(--clr-danger);
  }
  .loc-subgroup-body .tag-btn.btn-outline-danger:hover,
  .loc-subgroup-body .tag-btn.btn-outline-danger.active,
  .ub-subgroup-body .tag-btn.btn-outline-danger:hover,
  .ub-subgroup-body .tag-btn.btn-outline-danger.active {
    background: rgba(239,68,68,0.2);
    color: var(--clr-danger);
  }

  .loc-subgroup-body .tag-btn.btn-outline-secondary,
  .ub-subgroup-body .tag-btn.btn-outline-secondary {
    color: var(--white-a50);
    border-color: var(--white-a25);
  }
  .loc-subgroup-body .tag-btn.btn-outline-secondary:hover,
  .loc-subgroup-body .tag-btn.btn-outline-secondary.active,
  .ub-subgroup-body .tag-btn.btn-outline-secondary:hover,
  .ub-subgroup-body .tag-btn.btn-outline-secondary.active {
    background: var(--white-a10);
    color: var(--white-a80);
  }

  /* ══════════════════════════════════════
     Flatpickr dark theme inside
     loc/ub accordion bodies
     ══════════════════════════════════════ */
  .loc-accordion-body .flatpickr-calendar,
  .ub-accordion-body .flatpickr-calendar {
    background: rgba(30, 8, 20, 0.95);
    border: 1px solid var(--white-a10);
    box-shadow: 0 4px 16px rgba(0,0,0,0.4);
    color: var(--white-a85);
  }

  .loc-accordion-body .flatpickr-months,
  .ub-accordion-body .flatpickr-months {
    background: rgba(var(--clr-berry-500-rgb),0.2);
    color: var(--clr-white);
  }

  .loc-accordion-body .flatpickr-months .flatpickr-month,
  .ub-accordion-body .flatpickr-months .flatpickr-month {
    color: var(--clr-white);
    fill: var(--clr-white);
  }

  .loc-accordion-body .flatpickr-current-month,
  .ub-accordion-body .flatpickr-current-month {
    color: var(--clr-white);
  }

  .loc-accordion-body .flatpickr-current-month .flatpickr-monthDropdown-months,
  .ub-accordion-body .flatpickr-current-month .flatpickr-monthDropdown-months {
    background: rgba(30,8,20,0.95);
    color: var(--clr-white);
  }

  .loc-accordion-body .flatpickr-weekdays,
  .ub-accordion-body .flatpickr-weekdays {
    background: rgba(var(--clr-berry-500-rgb),0.15);
  }

  .loc-accordion-body .flatpickr-weekday,
  .ub-accordion-body .flatpickr-weekday {
    color: var(--white-a50);
    background: transparent;
  }

  .loc-accordion-body .flatpickr-day,
  .ub-accordion-body .flatpickr-day {
    color: var(--white-a75);
    border-color: transparent;
  }

  .loc-accordion-body .flatpickr-day:hover,
  .ub-accordion-body .flatpickr-day:hover {
    background: rgba(var(--clr-berry-500-rgb),0.25);
    color: var(--clr-white);
    border-color: transparent;
  }

  .loc-accordion-body .flatpickr-day.today,
  .ub-accordion-body .flatpickr-day.today {
    border-color: var(--clr-berry-400, #c4226e);
  }

  .loc-accordion-body .flatpickr-day.selected,
  .ub-accordion-body .flatpickr-day.selected {
    background: var(--clr-berry-500, #9e1a5e);
    border-color: var(--clr-berry-400, #c4226e);
    color: var(--clr-white);
  }

  .loc-accordion-body .flatpickr-day.prevMonthDay,
  .loc-accordion-body .flatpickr-day.nextMonthDay,
  .ub-accordion-body .flatpickr-day.prevMonthDay,
  .ub-accordion-body .flatpickr-day.nextMonthDay {
    color: var(--white-a20);
  }

  /* Nav arrows */
  .loc-accordion-body .flatpickr-prev-month,
  .loc-accordion-body .flatpickr-next-month,
  .ub-accordion-body .flatpickr-prev-month,
  .ub-accordion-body .flatpickr-next-month {
    color: var(--white-a60);
    fill: var(--white-a60);
  }

  .loc-accordion-body .flatpickr-prev-month:hover,
  .loc-accordion-body .flatpickr-next-month:hover,
  .ub-accordion-body .flatpickr-prev-month:hover,
  .ub-accordion-body .flatpickr-next-month:hover {
    color: var(--clr-white);
    fill: var(--clr-white);
  }

  /* ══════════════════════════════════════
     Use dates calc table dark theme
     ══════════════════════════════════════ */
  .loc-accordion-body .calc-table,
  .ub-accordion-body .calc-table,
  .loc-accordion-body .visit-calcs table,
  .ub-accordion-body .visit-calcs table {
    background: transparent;
    color: var(--white-a75);
    font-size: var(--fs-base-s);
    width: 100%;
  }

  .loc-accordion-body .calc-table th,
  .loc-accordion-body .calc-table td,
  .ub-accordion-body .calc-table th,
  .ub-accordion-body .calc-table td,
  .loc-accordion-body .visit-calcs th,
  .loc-accordion-body .visit-calcs td,
  .ub-accordion-body .visit-calcs th,
  .ub-accordion-body .visit-calcs td {
    background: transparent !important;
    border-color: var(--white-a08);
    color: var(--white-a75);
    padding: 3px 6px;
  }

  .loc-accordion-body .calc-table thead th,
  .ub-accordion-body .calc-table thead th,
  .loc-accordion-body .visit-calcs thead th,
  .ub-accordion-body .visit-calcs thead th {
    color: var(--text-muted);
    font-size: var(--label-font);
    text-transform: var(--label-transform);
    letter-spacing: 0.3px;
    border-bottom: 1px solid var(--white-a12);
  }

  .loc-accordion-body .calc-table tfoot,
  .ub-accordion-body .calc-table tfoot,
  .loc-accordion-body .visit-calcs tfoot,
  .ub-accordion-body .visit-calcs tfoot {
    border-top: 1px solid var(--white-a12);
    font-weight: 600;
    color: var(--white-a90);
  }

  /* Visit block container */
  .loc-accordion-body .visit-block,
  .ub-accordion-body .visit-block {
    background: var(--white-a02);
    border: 1px solid var(--white-a06);
    border-radius: var(--comp-radius-sm);
    padding: 8px;
    margin-bottom: 8px;
  }

  /* Visit inputs */
  .loc-accordion-body .visit-block input,
  .loc-accordion-body .visit-block select,
  .ub-accordion-body .visit-block input,
  .ub-accordion-body .visit-block select {
    background: var(--white-a04);
    border: 1px solid var(--white-a10);
    border-radius: var(--comp-radius-sm);
    color: var(--white-a85);
    font-size: var(--fs-base-s);
    padding: 3px 6px;
  }

  .loc-accordion-body .visit-block input:focus,
  .ub-accordion-body .visit-block input:focus {
    outline: var(--focus-outline);
    border-color: var(--focus-border);
    background: var(--white-a07);
  }

  /* ══════════════════════════════════════
     Hide flatpickr trigger input — the
     inline calendar renders adjacent,
     the input itself should not be visible
     ══════════════════════════════════════ */
  .loc-accordion-body .use-calendar-master,
  .ub-accordion-body .use-calendar-master {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 0;
    height: 0;
    padding: 0;
    border: none;
  }

  /* ══════════════════════════════════════
     All Scenes textarea dark theme
     ══════════════════════════════════════ */
  .loc-accordion-body textarea.edit-field,
  .ub-accordion-body textarea.edit-field,
  .loc-subgroup-body textarea.edit-field,
  .ub-subgroup-body textarea.edit-field {
    background: var(--white-a04);
    border: 1px solid var(--white-a10);
    border-radius: var(--comp-radius);
    color: var(--white-a85);
    font-size: var(--fs-md-s);
    padding: 6px 8px;
    width: 100%;
    resize: vertical;
    min-height: 80px;
  }

  .loc-accordion-body textarea.edit-field:focus,
  .ub-accordion-body textarea.edit-field:focus,
  .loc-subgroup-body textarea.edit-field:focus,
  .ub-subgroup-body textarea.edit-field:focus {
    outline: var(--focus-outline);
    border-color: var(--focus-border);
    background: var(--white-a07);
  }

  /* Scenes computed view */
  .loc-subgroup-body .scenes-computed,
  .ub-subgroup-body .scenes-computed {
    color: var(--white-a75);
    font-size: var(--fs-base-s);
  }

  .loc-subgroup-body .scene-line,
  .ub-subgroup-body .scene-line {
    color: var(--white-a75);
    padding: 1px 0;
  }

  .loc-mo-status { margin-left: auto; display: flex; align-items: center; }
  .loc-mo-trigger-btn { background: none; border: none; padding: 2px 4px; cursor: pointer; font-size: 14px; line-height: 1; display: flex; align-items: center; }
  .loc-mo-trigger-btn:hover { opacity: 0.8; }
  @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

  .loc-w3w-field-wrap { display: flex; align-items: center; gap: 4px; }
  .loc-w3w-input { flex: 1; }
  .loc-w3w-link { color: var(--text-placeholder); font-size: 12px; flex-shrink: 0; text-decoration: none; }
  .loc-w3w-link:hover { color: var(--clr-berry-400, #c4226e); }

  .loc-fields-3col { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0 16px; align-items: start; }
  @media (max-width: 900px) { .loc-fields-3col { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 480px) { .loc-fields-3col { grid-template-columns: 1fr; } }

  /* ── Add Location modal ── */
  .addloc-content { border: 1px solid rgba(var(--clr-berry-400-rgb),0.3); color: var(--clr-white); }
  .addloc-header { background: linear-gradient(135deg, var(--clr-berry-800) 0%, #150a1e 100%); border-bottom: 1px solid rgba(var(--clr-berry-400-rgb), .20); padding: 14px 18px; }
  .addloc-header .modal-title { color: var(--clr-white); font-size: 15px; font-weight: 600; }
  .addloc-header .btn-close { filter: invert(1) opacity(0.5); }
  .addloc-header .btn-close:hover { filter: invert(1) opacity(1); }
  .addloc-body { padding: 16px 18px; }
  .addloc-body h6, .addloc-section { font-size: 11px; font-weight: 700; color: var(--clr-berry-400, #d4537e); text-transform: uppercase; letter-spacing: 0.07em; margin: 12px 0 8px; padding-bottom: 4px; border-bottom: 1px solid rgba(var(--clr-berry-400-rgb),0.2); }
  .addloc-footer { background: rgba(var(--clr-berry-400-rgb), .04); border-top: 1px solid rgba(var(--clr-berry-400-rgb), .12); padding: 10px 18px; gap: 8px; }
  .addloc-footer .btn-secondary { background: var(--white-a07); border: 1px solid var(--white-a15); color: var(--white-a60); font-size: 12px; }
  /* Override base .btn-primary (purple) with berry pink for add-location modal context */
  .addloc-footer .btn-primary { background: rgba(var(--clr-berry-400-rgb),0.25); border: 1px solid var(--clr-berry-400); color: var(--clr-white); font-size: 12px; }
  .addloc-footer .btn-primary:hover { background: rgba(var(--clr-berry-400-rgb),0.45); }

  /* ── MO Image Slots ── */
  .mo-slots-toolbar { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; border-bottom: 1px solid var(--white-a06); flex-shrink: 0; }
  .mo-slot-add-btn { background: rgba(var(--clr-berry-400-rgb),0.12); border: 1px solid rgba(var(--clr-berry-400-rgb),0.3); border-radius: var(--comp-radius); color: var(--clr-berry-400, #d4537e); font-size: 10px; padding: 3px 10px; cursor: pointer; }
  .mo-slot-add-btn:hover { background: rgba(var(--clr-berry-400-rgb),0.25); }
  .mo-slots-section { padding: 10px 12px 4px; }
  .mo-slots-section-hdr { font-size: var(--label-font); font-weight: var(--label-weight); color: var(--white-a25); text-transform: var(--label-transform); letter-spacing: 0.06em; margin-bottom: 8px; padding-bottom: 4px; border-bottom: 1px solid var(--white-a05); }
  .mo-slots-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 8px; }
  .mo-slot-frame { border-radius: var(--comp-radius); overflow: hidden; border: 1px solid var(--white-a08); background: #0a0006; transition: border-color 0.15s; }
  .mo-slot-empty { border: 1px dashed var(--white-a10); }
  .mo-slot-drag-over { border-color: var(--clr-berry-400, #d4537e) !important; background: rgba(var(--clr-berry-400-rgb),0.06); }
  .mo-slot-uploading { opacity: 0.6; pointer-events: none; }
  .mo-slot-drop-zone { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 16px 10px; cursor: pointer; min-height: 100px; transition: background 0.15s; }
  .mo-slot-drop-zone:hover { background: rgba(var(--clr-berry-400-rgb), 0.08); }
  .mo-slot-drop-zone:hover i { color: var(--white-a25) !important; }
  .mo-slot-drop-label { font-size: 9px; font-weight: 600; color: var(--text-placeholder); text-align: center; line-height: 1.3; }
  .mo-slot-drop-hint { font-size: 8px; color: var(--white-a15); text-align: center; }
  .mo-slot-thumb { width: 100%; height: 100px; background-size: cover; background-position: center; cursor: pointer; transition: opacity 0.15s; }
  .mo-slot-thumb:hover { opacity: 0.85; }
  .mo-slot-bar { display: flex; align-items: center; justify-content: space-between; padding: 4px 8px; background: rgba(0,0,0,0.4); border-top: 1px solid var(--white-a06); }
  .mo-slot-label { font-size: 8px; color: var(--white-a60); font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .mo-slot-del { background: none; border: none; color: var(--white-a20); cursor: pointer; font-size: 14px; line-height: 1; padding: 0 0 0 6px; flex-shrink: 0; }
  .mo-slot-del:hover { color: var(--clr-danger); }
  .mo-slot-filled .mo-slot-bar { background: rgba(40,199,111,0.08); }
  .mo-slots-loading { padding: 20px; font-size: 11px; color: var(--white-a20); font-style: italic; }
  .mo-lb-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.9); z-index: var(--z-lightbox); display: none; align-items: center; justify-content: center; flex-direction: column; gap: 12px; }
  .mo-lb-inner { position: relative; max-width: 90vw; max-height: 90vh; display: flex; flex-direction: column; align-items: center; gap: 8px; }
  .mo-lb-close { position: absolute; top: -36px; right: 0; background: none; border: none; color: white; font-size: 28px; cursor: pointer; line-height: 1; }
  .mo-lb-label { font-size: 11px; color: var(--white-a50); font-weight: 600; }
  .mo-lb-img { max-width: 90vw; max-height: 80vh; object-fit: contain; border-radius: var(--comp-radius); }

  /* ══════════════════════════════════════
     Servicing tab — three-column grid
     ══════════════════════════════════════ */
  .loc-serv-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
  }
  @media (max-width: 768px) {
    .loc-serv-grid {
      grid-template-columns: 1fr;
    }
  }

  /* .loc-section-header/title/line replaced by .fm-labelled-divider/label/line */
  .loc-section-block {
    border-radius: var(--comp-radius);
    padding: 8px;
    margin-bottom: 4px;
  }
  .loc-section-loc-serv {
    background: var(--white-a03);
  }
  .loc-section-protection {
    background: rgba(var(--clr-berry-400-rgb), 0.04);
  }
  .loc-section-extra-gear {
    background: var(--white-a05);
  }

  /* ══════════════════════════════════════
     Planning & Prep tab — two-column grid
     ══════════════════════════════════════ */
  .loc-planning-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 16px;
  }
  .loc-planning-grid .loc-fields-3col {
    grid-template-columns: 1fr;
  }
  @media (max-width: 768px) {
    .loc-planning-grid {
      grid-template-columns: 1fr;
    }
  }

  /* ══════════════════════════════════════
     Movement Order tab — two-column grid
     ══════════════════════════════════════ */
  .loc-mo-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 16px;
  }
  .loc-mo-grid .loc-fields-3col {
    grid-template-columns: 1fr;
  }
  @media (max-width: 768px) {
    .loc-mo-grid {
      grid-template-columns: 1fr;
    }
  }

  /* ══════════════════════════════════════
     Cycling pill tri-state
     ══════════════════════════════════════ */
  .ls-cycle-pill {
    display: inline-block;
    padding: 2px 10px;
    border-radius: var(--comp-radius-pill);
    font-size: var(--fs-base-s);
    font-weight: 500;
    cursor: pointer;
    user-select: none;
    transition: background 0.15s, color 0.15s;
  }
  .ls-state-tbd {
    background: var(--badge-amber-bg);
    color: var(--badge-amber-text);
    border: 1px solid var(--badge-amber-bd);
  }
  .ls-state-no {
    background: var(--white-a07);
    color: var(--white-a50);
    border: 1px solid var(--white-a15);
  }
  .ls-state-yes {
    background: rgba(40,199,111,0.18);
    color: var(--clr-success);
    border: 1px solid rgba(40,199,111,0.35);
  }
  .ls-state-pre-yes {
    background: rgba(40,199,111,0.07);
    color: rgba(40,199,111,0.45);
    border: 1px solid rgba(40,199,111,0.15);
  }
  .ls-state-pre-no {
    background: var(--white-a03);
    color: var(--white-a30);
    border: 1px solid var(--white-a08);
  }
  .ls-row {
    display: grid;
    grid-template-columns: var(--ls-label-col, 200px) auto 1fr;
    align-items: center;
    gap: 0 10px;
    padding: 4px 0;
    border-bottom: 0.5px solid var(--white-a06);
  }
  .ls-sub-fields {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
  }
  .ls-sub-fields.ls-hide {
    display: none !important;
  }
  .ls-state-pending {
    background: var(--white-a07);
    color: var(--white-a50);
    border: 1px solid var(--white-a15);
  }
  @media (max-width: 768px) {
    .ls-row {
      grid-template-columns: 1fr;
    }
  }

  /* ── 4-column fees layout ── */
  .loc-fees-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border: 1px solid var(--white-a08);
    border-radius: var(--comp-radius);
    overflow: hidden;
  }

  .loc-fees-col {
    padding: 10px 12px;
    border-right: 1px solid var(--white-a06);
  }
  .loc-fees-col:last-child {
    border-right: none;
  }

  .loc-fees-col-header {
    font-size: var(--fs-xs-s);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--white-a40);
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--white-a06);
  }

  .loc-fees-estimated .loc-fees-col-header {
    color: var(--white-a35);
  }

  .loc-fees-agreed .loc-fees-col-header {
    color: rgba(var(--clr-berry-400-rgb), 0.70);
  }

  .loc-fees-row {
    margin-bottom: 8px;
    display: flex;
    flex-direction: column;
    gap: 3px;
  }
  .loc-fees-row:last-child { margin-bottom: 0; }

  .loc-fees-row label {
    font-size: var(--fs-xs-s);
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--white-a30);
  }

  .loc-fees-input {
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    border-radius: var(--comp-radius);
    color: var(--white-a85);
    font-size: var(--fs-base-s);
    padding: 4px 7px;
    width: 100%;
    transition: opacity 0.2s;
  }

  .loc-fees-input:focus {
    border-color: var(--focus-border);
    box-shadow: var(--focus-shadow);
    outline: none;
  }

  /* Dimmed state — when agreed col has a value */
  .loc-fees-col.is-dimmed {
    opacity: 0.35;
  }
  .loc-fees-col.is-dimmed .loc-fees-col-header {
    color: var(--white-a20);
  }

  /* Responsive — stack to 2 cols on narrow */
  @media (max-width: 900px) {
    .loc-fees-grid {
      grid-template-columns: 1fr 1fr;
    }
    .loc-fees-col:nth-child(2) {
      border-right: none;
    }
    .loc-fees-col:nth-child(3) {
      border-top: 1px solid var(--white-a06);
    }
  }


  /* ══════════════════════════════════════
     Recce Notes tab
     ══════════════════════════════════════ */
  .loc-rn-container { padding: 8px 0; }
  .loc-rn-loading { padding: 16px; color: var(--white-a40); font-size: var(--fs-lg-s); }
  .loc-rn-recce {
    border: 0.5px solid var(--white-a10);
    border-radius: var(--comp-radius);
    margin-bottom: 8px;
    overflow: hidden;
  }
  .loc-rn-header {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 12px; background: var(--white-a04);
    cursor: pointer; user-select: none;
  }
  .loc-rn-header:hover { background: var(--white-a07); }
  .loc-rn-date { font-size: var(--fs-md-s); font-weight: 600; color: var(--clr-berry-300); white-space: nowrap; }
  .loc-rn-title { font-size: var(--fs-md-s); color: var(--white-a70); flex: 1; }
  .loc-rn-count { font-size: var(--fs-base-s); color: var(--white-a40); }
  .loc-rn-chevron { color: var(--white-a40); transition: transform 0.2s; flex-shrink: 0; }
  .loc-rn-body { padding: 8px 12px; }
  .loc-rn-submission { border-bottom: 0.5px solid var(--white-a06); padding: 10px 0; }
  .loc-rn-submission.is-consolidated { opacity: 0.55; }
  .loc-rn-sub-header { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
  .loc-rn-user { font-size: var(--fs-md-s); font-weight: 600; color: var(--white-a80); }
  .loc-rn-time { font-size: var(--fs-base-s); flex: 1; }
  .loc-rn-badge { font-size: var(--fs-sm-s); padding: 2px 8px; border-radius: var(--comp-radius-pill); }
  .loc-rn-consolidated { background: rgba(40,199,111,0.15); color: #28c76f; border: 1px solid rgba(40,199,111,0.3); }
  .loc-rn-toggles { margin-bottom: 6px; }
  .loc-rn-field-row {
    display: flex; align-items: center; flex-wrap: wrap; gap: 6px;
    padding: 3px 0; border-bottom: 0.5px solid var(--white-a05); font-size: var(--fs-md-s);
  }
  .loc-rn-field-label { color: var(--white-a70); min-width: 140px; flex-shrink: 0; }
  .loc-rn-val { font-size: var(--fs-sm-s); padding: 1px 6px; border-radius: var(--comp-radius-pill); }
  .loc-rn-val-yes { background: rgba(40,199,111,0.15); color: #28c76f; }
  .loc-rn-val-no { background: var(--white-a07); color: var(--white-a50); }
  .loc-rn-sub {
    font-size: var(--fs-base-s); color: var(--white-a50);
    background: var(--white-a05); padding: 1px 6px; border-radius: var(--comp-radius-pill);
  }
  .loc-rn-notes {
    font-size: var(--fs-md-s); color: var(--white-a70); padding: 6px 0;
    border-top: 0.5px solid var(--white-a06); margin-top: 4px; white-space: pre-wrap;
  }
  .loc-rn-vn-list { margin-top: 6px; }
  .loc-rn-cons-btn {
    font-size: var(--fs-sm-s); padding: 2px 8px; border-radius: var(--comp-radius-pill);
    border: 1px solid var(--white-a20); background: transparent; color: var(--white-a60); cursor: pointer;
  }
  .loc-rn-cons-btn:hover { border-color: var(--white-a40); color: var(--white-a80); }
  .loc-rn-uncons-btn {
    font-size: var(--fs-sm-s); padding: 2px 8px; border-radius: var(--comp-radius-pill);
    border: 1px solid var(--white-a20); background: transparent; color: var(--white-a60); cursor: pointer;
  }
  .loc-rn-uncons-btn:hover { border-color: var(--white-a40); color: var(--white-a80); }
  .loc-rn-del-btn {
    font-size: var(--fs-sm-s); padding: 2px 8px; border-radius: var(--comp-radius-pill);
    border: 1px solid rgba(220,53,69,0.4); background: transparent; color: rgba(220,53,69,0.7); cursor: pointer;
  }
  .loc-rn-del-btn:hover { border-color: rgba(220,53,69,0.7); color: rgba(220,53,69,1); }
  .loc-rn-cons-all-btn {
    font-size: var(--fs-base-s); padding: 6px 14px; border-radius: var(--comp-radius);
    border: 1px solid rgba(var(--clr-berry-400-rgb), 0.4);
    background: rgba(var(--clr-berry-400-rgb), 0.1);
    color: var(--clr-berry-300); cursor: pointer; width: 100%; margin-top: 8px;
  }
  .loc-rn-cons-all-btn:hover { background: rgba(var(--clr-berry-400-rgb), 0.18); }
  .loc-rn-footer { padding: 4px 0 8px; }

}
