@import url('./main-layout.css');
@import url('./views/main-view.css');

/* Button styling */
/* Primary action button */
.button-primary {
  background-color: var(--lumo-primary-color);
  color: var(--lumo-base-color);
  font-weight: 600;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: var(--lumo-space-s) var(--lumo-space-m);
  transition: all 0.2s ease;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  height: var(--lumo-size-m);
  margin-right: var(--lumo-space-s);
}

.button-primary:hover {
  background-color: var(--lumo-primary-color-50pct);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

/* Secondary action button */
.button-secondary {
  background-color: var(--lumo-contrast);
  color: var(--lumo-base-color);
  font-weight: 500;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: var(--lumo-space-s) var(--lumo-space-m);
  transition: all 0.2s ease;
  height: var(--lumo-size-m);
  margin-right: var(--lumo-space-s);
}

.button-secondary:hover {
  background-color: var(--lumo-contrast-60pct);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

/* Tertiary action button */
.button-tertiary {
  background-color: var(--lumo-contrast-20pct);
  color: var(--lumo-secondary-text-color);
  font-weight: 500;
  border-radius: 8px;
  padding: var(--lumo-space-s) var(--lumo-space-m);
  transition: all 0.2s ease;
  height: var(--lumo-size-m);
  margin-right: var(--lumo-space-s);
}

.button-tertiary:hover {
  background-color: var(--lumo-contrast-30pct);
  color: var(--lumo-primary-text-color);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Warning/danger action button */
.button-danger {
  background-color: var(--lumo-error-color);
  color: var(--lumo-base-color);
  font-weight: 500;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: var(--lumo-space-s) var(--lumo-space-m);
  transition: all 0.2s ease;
  height: var(--lumo-size-m);
  margin-right: var(--lumo-space-s);
}

.button-danger:hover {
  background-color: var(--lumo-error-color-50pct);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

/* Success action button */
.button-success {
  background-color: var(--lumo-success-color);
  color: var(--lumo-base-color);
  font-weight: 500;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: var(--lumo-space-s) var(--lumo-space-m);
  transition: all 0.2s ease;
  height: var(--lumo-size-m);
  margin-right: var(--lumo-space-s);
}

.button-success:hover {
  background-color: var(--lumo-success-color-50pct);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

/* Info action button */
.button-info {
  background-color: var(--lumo-primary-color);
  color: var(--lumo-base-color);
  font-weight: 500;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: var(--lumo-space-s) var(--lumo-space-m);
  transition: all 0.2s ease;
  height: var(--lumo-size-m);
  margin-right: var(--lumo-space-s);
}

.button-info:hover {
  background-color: var(--lumo-primary-color-50pct);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

/* Button with icon styling */
.button-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.button-icon iron-icon,
.button-icon vaadin-icon {
  margin-right: var(--lumo-space-xs);
}

/* Action buttons container */
.action-buttons {
  display: flex;
  gap: var(--lumo-space-s);
  margin-top: var(--lumo-space-m);
  padding: var(--lumo-space-s);
  border-radius: 8px;
  background-color: var(--lumo-contrast-5pct);
}

/* Grid styling for tables */
vaadin-grid {
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}

/* Header styling */
vaadin-grid::part(header-cell) {
  background-color: #e0ebfd;
  font-weight: bold;
  font-size: var(--lumo-font-size-m);
  color: var(--lumo-primary-text-color);
  border-bottom: 2px solid var(--lumo-primary-color-50pct);
  padding: var(--lumo-space-s) var(--lumo-space-m);
}

/* Cell styling */
vaadin-grid::part(cell) {
  padding: var(--lumo-space-s) var(--lumo-space-m);
  border-right: 1px solid var(--lumo-contrast-10pct);
  border-bottom: 1px solid var(--lumo-contrast-10pct);
}

/* Last column cell - remove right border */
vaadin-grid::part(cell):last-child {
  border-right: none;
}

/* Row hover effect */
vaadin-grid::part(row):hover {
  background-color: var(--lumo-primary-color-5pct);
}

/* Alternating row colors */
vaadin-grid::part(row):nth-child(even) {
  background-color: var(--lumo-contrast-5pct);
}

/* Selected row styling */
vaadin-grid::part(row)[selected] {
  background-color: var(--lumo-primary-color-10pct);
}

/* First column styling for better visual hierarchy */
vaadin-grid-column:first-child::part(cell) {
  font-weight: 500;
}

/* Specific styles for the parcels grid */
.parcels-grid {
  --lumo-font-family: var(--lumo-font-family);
  --lumo-line-height-s: 1.2;
  --lumo-line-height-m: 1.4;
  --lumo-space-wide-xl: 2.5rem;
}

/* Enhanced header styling for parcels grid */
.parcels-grid::part(header-cell) {
  background-color: #e0ebfd;
  font-weight: 600;
  text-transform: uppercase;
  font-size: var(--lumo-font-size-s);
  letter-spacing: 0.03em;
  color: var(--lumo-primary-text-color);
  border-bottom: 2px solid var(--lumo-primary-color);
  padding: var(--lumo-space-s) var(--lumo-space-m);
  height: var(--lumo-size-xl);
}

/* Cell styling for parcels grid */
.parcels-grid::part(cell) {
  padding: var(--lumo-space-s) var(--lumo-space-m);
  font-size: var(--lumo-font-size-s);
  border-right: 1px solid var(--lumo-contrast-10pct);
  border-bottom: 1px solid var(--lumo-contrast-10pct);
}

/* Frozen column styling - improved for Vaadin 24.6.5 */
.parcels-grid [frozen]::part(cell) {
  font-weight: 500;
  background-color: var(--lumo-base-color);
  box-shadow: 1px 0 5px rgba(0, 0, 0, 0.1);
  z-index: 10;
  position: sticky !important;
  left: 0;
}

/* Frozen header styling */
.parcels-grid [frozen]::part(header-cell) {
  background-color: #e0ebfd;
  z-index: 11;
  position: sticky !important;
  left: 0;
}

/* Ensure frozen columns have proper background */
.parcels-grid::part(frozen-column) {
  background-color: var(--lumo-base-color);
  z-index: 10;
}

/* Fix for frozen column headers */
.parcels-grid thead tr th:first-child {
  position: sticky !important;
  left: 0;
  z-index: 11;
  background-color: var(--lumo-primary-color-10pct);
}

/* Fix for frozen column group headers */
.parcels-grid thead tr:first-child th:first-child {
  position: sticky !important;
  left: 0;
  z-index: 12;
  background-color: var(--lumo-primary-color);
}

/* Ensure non-frozen headers scroll properly */
.parcels-grid thead tr th:not(:first-child) {
  position: relative;
  z-index: 1;
}

/* Ensure non-frozen group headers scroll properly */
.parcels-grid thead tr:first-child th:not(:first-child) {
  position: relative;
  z-index: 2;
}

/* Fix for header row cells */
.parcels-grid vaadin-grid-cell-content {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Fix for header row */
.parcels-grid vaadin-grid-header-row {
  overflow: visible;
}

/* Fix for scrolling behavior */
.parcels-grid vaadin-grid-scroller {
  overflow: auto;
}

/* Fix for horizontal scrolling */
.parcels-grid [part="body-cell"]:not([frozen]) {
  overflow: visible;
}

/* Fix for Vaadin 24.6.5 specific issues */
.parcels-grid [part="row"] {
  overflow: visible !important;
}

/* Row hover effect for parcels grid */
.parcels-grid::part(row):hover {
  background-color: var(--lumo-primary-color-5pct);
  cursor: pointer;
}

/* Alternating row colors for parcels grid */
.parcels-grid::part(row):nth-child(even) {
  background-color: var(--lumo-contrast-5pct);
}

/* Selected row styling for parcels grid */
.parcels-grid::part(row)[selected] {
  background-color: var(--lumo-primary-color-10pct);
}

/* Enhanced summary footer styling */
.parcels-grid.has-summary-footer::part(footer-cell) {
  border-top: 2px solid var(--lumo-primary-color) !important;
  box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.05) !important;
  font-weight: bold !important;
  color: var(--lumo-primary-text-color) !important;
  height: var(--lumo-size-l) !important;
}

/* First cell in summary footer (SUMA text) */
.parcels-grid.has-summary-footer::part(footer-cell):first-child {
  font-size: var(--lumo-font-size-m) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

/* Hover effect for summary footer cells */
.parcels-grid.has-summary-footer::part(footer-cell):hover {
  transition: background-color 0.2s ease !important;
}

/* Ensure the summary footer is always visible */
.parcels-grid.has-summary-footer::part(footer) {
  position: sticky !important;
  bottom: 0 !important;
  z-index: 100 !important;
}

/* Ensure the summary footer text is properly aligned */
.parcels-grid.has-summary-footer vaadin-grid-cell-content {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  height: 100% !important;
}

/* Add a subtle animation when values are updated */
@keyframes highlight {
  0% { background-color: var(--lumo-primary-color-50pct); }
  100% { background-color: var(--lumo-primary-color-20pct); }
}

/* Row details styling */
.parcels-grid [part="details-cell"] {
  background-color: var(--lumo-contrast-5pct);
  border-bottom: 1px solid var(--lumo-contrast-20pct);
  padding: var(--lumo-space-m);
}

/* Column group header styling */
.parcels-grid thead tr:first-child th {
  background-color: var(--lumo-primary-color);
  color: var(--lumo-base-color);
  font-weight: bold;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--lumo-space-xs) var(--lumo-space-s);
  border-bottom: 1px solid var(--lumo-contrast-30pct);
  border-right: 1px solid var(--lumo-contrast-30pct);
  z-index: 1;
}

/* Frozen column group header styling */
.parcels-grid thead tr:first-child th[frozen] {
  background-color: var(--lumo-primary-color);
  z-index: 3;
  position: relative;
}

/* Last column in group - remove right border */
.parcels-grid thead tr:first-child th:last-child {
  border-right: none;
}

.form-section {
    border: 1px solid var(--lumo-contrast-20pct);
    border-radius: 8px;
    padding: 8px;
    margin-bottom: 8px;
    background-color: var(--lumo-base-color);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.form-section-heading {
    margin-top: 0;
    margin-bottom: 8px;
    color: var(--lumo-primary-text-color);
    font-size: var(--lumo-font-size-m);
    font-weight: 500;
}

.form-section:hover {
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.2s ease-in-out;
}

.compact-form-layout {
    --lumo-space-m: 0.5em;
}

.compact-form-field {
    --lumo-text-field-size: var(--lumo-size-s);
    margin-top: 0;
    margin-bottom: 0;
    height: auto;
    min-height: var(--lumo-size-s);
}

.compact-form-layout vaadin-form-layout {
    margin-top: 0;
    margin-bottom: 0;
}

.parcel-form-field {
    margin-top: 0;
    margin-bottom: 4px;
    min-height: 2em;
}

vaadin-combo-box.parcel-form-field::part(input-field) {
    min-height: 2em;
    height: 2em;
}

vaadin-text-field.parcel-form-field::part(input-field),
vaadin-big-decimal-field.parcel-form-field::part(input-field) {
    min-height: 2em;
    height: 2em;
}

.form-section vaadin-form-layout {
    margin: 0;
    padding: 0;
}

.form-section vaadin-form-item {
    padding: 0;
    margin: 0;
}

/* Dictionary detail view styling */
.dictionary-detail {
    background-color: var(--lumo-contrast-5pct);
    border-radius: 8px;
    padding: var(--lumo-space-m);
    margin-top: var(--lumo-space-s);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.dictionary-info-section {
    background-color: var(--lumo-primary-color-10pct);
    border-radius: 4px;
    padding: var(--lumo-space-m);
    margin-bottom: var(--lumo-space-m);
}

.dictionary-parameters-grid {
    border: 1px solid var(--lumo-contrast-10pct);
    border-radius: 4px;
    overflow: hidden;
}

.dictionary-parameters-grid::part(header-cell) {
    background-color: var(--lumo-primary-color-10pct);
    font-weight: bold;
}

.dictionary-parameters-grid::part(row):hover {
    background-color: var(--lumo-primary-color-5pct);
}

.dictionary-add-parameter {
    display: flex;
    gap: var(--lumo-space-s);
    margin-top: var(--lumo-space-m);
    padding: var(--lumo-space-s);
    background-color: var(--lumo-contrast-5pct);
    border-radius: 4px;
    align-items: center;
}

.dictionary-add-parameter vaadin-text-field {
    flex-grow: 1;
}

/* Styling for the dictionaries grid */
.dictionaries-grid {
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.dictionaries-grid::part(header-cell) {
    background-color: #e0ebfd;
    font-weight: bold;
    font-size: var(--lumo-font-size-m);
    color: var(--lumo-primary-text-color);
    border-bottom: 2px solid var(--lumo-primary-color-50pct);
    padding: var(--lumo-space-s) var(--lumo-space-m);
}

.dictionaries-grid::part(row):hover {
    background-color: var(--lumo-primary-color-5pct);
    cursor: pointer;
}

.dictionaries-grid::part(row)[selected] {
    background-color: var(--lumo-primary-color-10pct);
}

.dictionaries-grid [part="details-cell"] {
    background-color: var(--lumo-contrast-5pct);
    border-bottom: 1px solid var(--lumo-contrast-20pct);
    padding: var(--lumo-space-m);
}

.confirm-dialog {
    width: 400px;
}

.confirm-dialog-header {
    border-bottom: 1px solid #e0e0e0;
    margin: 0;
    padding-bottom: 10px;
    font-size: 1.25rem;
    font-weight: 600;
}

.confirm-dialog-message {
    padding: 20px 0;
    text-align: center;
}

.confirm-dialog-button-confirm {
    background-color: var(--lumo-primary-color);
    color: var(--lumo-primary-contrast-color);
}

.confirm-dialog-button-cancel {
    background-color: var(--lumo-contrast-10pct);
    color: var(--lumo-body-text-color);
}

.user-form-header {
    margin: 0;
    padding-bottom: 10px;
    border-bottom: 1px solid #e0e0e0;
    font-size: 1.25rem;
    font-weight: 500;
}

.dialog-form-header {
    margin: 0;
    padding-bottom: 10px;
    border-bottom: 1px solid #e0e0e0;
    font-size: 1.25rem;
    font-weight: 500;
}

.dialog-form-header-wrapper {
    margin-bottom: 15px;
}

/* Filter bar styling */
.filter-container {
    display: flex;
    align-items: center;
    background-color: var(--lumo-contrast-5pct);
    border-radius: var(--lumo-border-radius-m);
    padding: var(--lumo-space-s);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.2s ease-in-out, transform 0.2s ease;
    width: 100%;
}

.filter-container:hover {
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
    transform: translateY(-1px);
}

/* Filter details component styling */
vaadin-details.filter-details {
    margin-bottom: var(--lumo-space-s);
    width: 100%;
}

vaadin-details.filter-details::part(summary) {
    cursor: pointer;
    user-select: none;
}

vaadin-details.filter-details::part(toggle) {
    color: var(--lumo-primary-color);
    transition: transform 0.3s;
}

vaadin-details.filter-details[opened]::part(toggle) {
    transform: rotate(90deg);
}

vaadin-details.filter-details .filter-icon {
    color: var(--lumo-primary-color);
}

.filter-combo-box {
    margin-right: var(--lumo-space-m);
    min-width: 200px;
    margin-bottom: var(--lumo-space-s);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.filter-combo-box:focus-within {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.filter-combo-box::part(input-field) {
    background-color: var(--lumo-base-color);
    border-radius: var(--lumo-border-radius-s);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.filter-combo-box::part(toggle-button) {
    color: var(--lumo-primary-color);
}

.filter-combo-box:hover::part(input-field) {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.filter-combo-box[focused]::part(input-field) {
    box-shadow: 0 0 0 2px var(--lumo-primary-color-50pct);
}

.filter-text-field {
    margin-right: var(--lumo-space-m);
    min-width: 200px;
    margin-bottom: var(--lumo-space-s);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.filter-text-field:focus-within {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.filter-text-field::part(input-field) {
    background-color: var(--lumo-base-color);
    border-radius: var(--lumo-border-radius-s);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.filter-text-field:hover::part(input-field) {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.filter-text-field[focused]::part(input-field) {
    box-shadow: 0 0 0 2px var(--lumo-primary-color-50pct);
}

/* Clear filters button styling */
.button-tertiary.filter-clear-button {
    margin-left: var(--lumo-space-s);
    height: var(--lumo-size-s);
    font-size: var(--lumo-font-size-s);
    color: var(--lumo-secondary-text-color);
    background-color: var(--lumo-contrast-10pct);
    border-radius: var(--lumo-border-radius-m);
    padding: 0 var(--lumo-space-s);
    transition: all 0.2s ease;
}

.button-tertiary.filter-clear-button:hover {
    background-color: var(--lumo-contrast-20pct);
    color: var(--lumo-primary-text-color);
}

/* Filter section title styling */
.filter-title {
    font-size: var(--lumo-font-size-m);
    font-weight: 500;
    color: var(--lumo-primary-text-color);
    margin: 0;
    margin-right: var(--lumo-space-m);
    white-space: nowrap;
}

/* Responsive filter layout */
@media (max-width: 1200px) {
    .filter-combo-box {
        width: 180px;
    }
}

/* Billing Period Management View Styles */
.billing-period-grid {
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.billing-period-grid::part(header-cell) {
    background-color: #e0ebfd;
    font-weight: bold;
    font-size: var(--lumo-font-size-m);
    color: var(--lumo-primary-text-color);
    border-bottom: 2px solid var(--lumo-primary-color-50pct);
    padding: var(--lumo-space-s) var(--lumo-space-m);
}

.billing-period-grid::part(row):hover {
    background-color: var(--lumo-primary-color-5pct);
    cursor: pointer;
}

.billing-period-grid::part(row)[selected] {
    background-color: var(--lumo-primary-color-10pct);
}

.status-active {
    color: var(--lumo-success-color);
    font-weight: bold;
}

.status-inactive {
    color: var(--lumo-secondary-text-color);
}

.view-title {
    color: var(--lumo-primary-text-color);
    margin: 0 0 var(--lumo-space-m) 0;
    font-size: var(--lumo-font-size-xl);
    font-weight: 600;
}

@media (max-width: 960px) {
    .filter-combo-box {
        width: 160px;
    }
}

@media (max-width: 768px) {
    .filter-combo-box,
    .filter-text-field {
        width: 140px;
    }

    .filter-container {
        flex-direction: column;
        align-items: stretch;
    }
}

@media (max-width: 600px) {
    .filter-combo-box,
    .filter-text-field {
        width: 100%;
        margin-right: 0;
    }
}

/* ParcelGrid Header Style */
.parcel-grid-header {
    background-color: var(--lumo-primary-color);
    color: var(--lumo-base-color);
    font-weight: bold;
    text-align: center;
}

/* ParcelGrid Summary Style */
.parcel-grid-summary {
    font-weight: bold;
    font-size: var(--lumo-font-size-m);
    color: var(--lumo-primary-text-color);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ParcelGrid Loading Style */
.parcel-grid-loading {
    font-style: italic;
    color: var(--lumo-secondary-text-color);
}

/* ParcelDetailView Styles */
.parcel-detail-view {
    background-color: var(--lumo-contrast-5pct);
    border-radius: 8px;
    padding: var(--lumo-space-m);
    justify-content: space-between;
}

.parcel-detail-section {
    border: 1px solid var(--lumo-contrast-20pct);
    border-radius: 4px;
    padding: 8px;
    margin-bottom: 8px;
    width: 100%;
}

.parcel-detail-section-title {
    font-weight: bold;
    font-size: 14px;
    color: var(--lumo-primary-text-color);
    display: block;
    margin-bottom: 8px;
    border-bottom: 1px solid var(--lumo-contrast-10pct);
    padding-bottom: 4px;
}

.parcel-detail-highlighted-section {
    background-color: var(--lumo-primary-color-10pct);
    border-left: 4px solid var(--lumo-primary-color);
    padding: 8px;
    margin-bottom: 8px;
    width: 99%;
}

.parcel-detail-secondary-section {
    background-color: var(--lumo-contrast-10pct);
    border-left: 4px solid var(--lumo-contrast);
    padding: 8px;
    margin-bottom: 8px;
    width: 99%;
}

.parcel-detail-info-field {
    margin-bottom: 4px;
    display: flex;
    justify-content: space-between;
}

.parcel-detail-info-label {
    font-weight: 500;
    color: var(--lumo-secondary-text-color);
    margin-right: 8px;
}

.parcel-detail-info-value {
    color: var(--lumo-primary-text-color);
    font-weight: normal;
}

.parcel-detail-resource-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 8px;
    border-radius: 4px;
    min-width: 120px;
    margin: 0 4px;
}

.parcel-detail-resource-value {
    font-size: 16px;
    font-weight: bold;
    color: var(--lumo-primary-color);
    margin-bottom: 2px;
}

.parcel-detail-resource-label {
    font-size: 11px;
    text-align: center;
    color: var(--lumo-secondary-text-color);
}

.parcel-detail-left-section {
    padding: 8px;
    margin-right: auto;
}

.parcel-detail-right-section {
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
    padding: 8px;
}

.data-source-section {
    margin-top: 10px;
}

.related-parcels-section {
    margin-top: 10px;
}

.related-parcels-group {
    margin-bottom: 5px;
}

.related-parcels-title {
    font-weight: bold;
    margin-right: 10px;
}

.parcel-link {
    text-decoration: underline;
    cursor: pointer;
    color: var(--lumo-primary-color);
}

.resource-changes-badge {
    margin-left: var(--lumo-space-xs);
    font-size: var(--lumo-font-size-s);
    background-color: white;
    color: var(--lumo-primary-color);
    font-weight: bold;
    border: 2px solid var(--lumo-primary-color-50pct);
}

/* Kontener dla sekcji szczegółów parceli */
.parcel-sections-container {
    display: flex;
    flex-wrap: wrap;
    gap: var(--lumo-space-m);
    width: 100%;
    margin-top: var(--lumo-space-xs);
    margin-bottom: var(--lumo-space-m);
}

/* Pojedyncza sekcja w kontenerze */
.parcel-section-item {
    flex: 1 1 calc(50% - var(--lumo-space-m));
    min-width: 300px;
    margin-bottom: var(--lumo-space-s);
    padding: var(--lumo-space-xs);
}

/* Responsywność dla małych ekranów */
@media (max-width: 960px) {
    .parcel-section-item {
        flex: 1 1 100%;
    }
}

/* Styl dla sekcji ostrzegawczej (nieedytowalna parcela) */
.parcel-detail-warning-section {
    background-color: var(--lumo-error-color-10pct);
    border-left: 4px solid var(--lumo-error-color);
    padding: 8px;
    margin-bottom: 8px;
    width: 99%;
}

.parcel-detail-warning-message {
    color: var(--lumo-error-color);
    font-weight: bold;
    font-size: 14px;
    display: flex;
    align-items: center;
}

.parcel-detail-warning-message iron-icon,
.parcel-detail-warning-message vaadin-icon {
    margin-right: var(--lumo-space-xs);
    color: var(--lumo-error-color);
}

/* Resource Change Reason Dialog Styles */
.resource-difference-label {
    font-weight: bold;
}

.current-sum-label-match {
    color: green;
}

.current-sum-label-mismatch {
    color: red;
}

.confirm-button-error-primary {
    background-color: var(--lumo-error-color);
    color: var(--lumo-base-color);
    font-weight: 500;
}

/* Wyróżnienie zmienionych pól */
.parcel-detail-changed-field {
    background-color: #fff3cd !important;
    border-left: 3px solid #ff8c00 !important;
    position: relative;
    padding: 4px 8px;
    border-radius: 4px;
    margin: 2px 0;
}

.parcel-detail-changed-value {
    color: #ff8c00 !important;
    font-weight: bold !important;
}

/* Tooltip z pierwotną wartością */
.parcel-detail-original-value-tooltip {
    position: absolute;
    background-color: #333;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    z-index: 1000;
    display: none;
    white-space: nowrap;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.parcel-detail-original-value-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: #333 transparent transparent transparent;
}

.parcel-detail-changed-field:hover .parcel-detail-original-value-tooltip {
    display: block;
}

/* Specjalne style dla resource display */
.parcel-detail-resource-display.parcel-detail-changed-field {
    background-color: #fff3cd;
    border: 2px solid #ff8c00;
}

.parcel-detail-resource-display.parcel-detail-changed-field .parcel-detail-resource-value {
    color: #ff8c00;
    font-weight: bold;
}

/* Delete Parcel Dialog Styling */
.delete-parcel-dialog {
    --lumo-border-radius-l: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
    border: 1px solid var(--lumo-contrast-10pct);
}

.delete-dialog-header {
    background: linear-gradient(135deg, var(--lumo-base-color) 0%, var(--lumo-contrast-5pct) 100%);
    border-bottom: 1px solid var(--lumo-contrast-10pct);
}

.delete-dialog-content {
    background-color: var(--lumo-base-color);
}

.delete-dialog-footer {
    background: linear-gradient(135deg, var(--lumo-contrast-5pct) 0%, var(--lumo-contrast-10pct) 100%);
    border-top: 1px solid var(--lumo-contrast-10pct);
}

.delete-warning-card {
    background: linear-gradient(135deg, var(--lumo-error-color-10pct) 0%, var(--lumo-error-color-5pct) 100%);
    border: 1px solid var(--lumo-error-color-50pct);
    border-radius: 8px;
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.delete-warning-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--lumo-error-color) 0%, var(--lumo-error-color-50pct) 100%);
}

.delete-warning-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(244, 67, 54, 0.15);
}

.delete-warning-icon {
    color: var(--lumo-error-color);
    filter: drop-shadow(0 2px 4px rgba(244, 67, 54, 0.2));
    animation: pulse-warning 2s infinite;
}

@keyframes pulse-warning {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}

.delete-warning-title {
    color: var(--lumo-error-text-color);
    font-weight: 600;
    line-height: 1.3;
    margin: 0;
}

.delete-warning-description {
    color: var(--lumo-secondary-text-color);
    line-height: 1.5;
    margin: 0;
    opacity: 0.9;
}

.delete-dialog-button-cancel {
    background-color: var(--lumo-contrast-10pct);
    color: var(--lumo-body-text-color);
    border: 1px solid var(--lumo-contrast-20pct);
    transition: all 0.2s ease;
}

.delete-dialog-button-cancel:hover {
    background-color: var(--lumo-contrast-20pct);
    border-color: var(--lumo-contrast-30pct);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.delete-dialog-button-confirm {
    background: linear-gradient(135deg, var(--lumo-error-color) 0%, var(--lumo-error-color-50pct) 100%);
    color: var(--lumo-base-color);
    border: none;
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
}

.delete-dialog-button-confirm::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.delete-dialog-button-confirm:hover::before {
    left: 100%;
}

.delete-dialog-button-confirm:hover {
    background: linear-gradient(135deg, var(--lumo-error-color-50pct) 0%, var(--lumo-error-color) 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(244, 67, 54, 0.3);
}

.delete-dialog-button-confirm:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(244, 67, 54, 0.2);
}

/* Responsive adjustments for delete dialog */
@media (max-width: 600px) {
    .delete-parcel-dialog {
        width: 95vw !important;
        max-width: 95vw !important;
        margin: 0 auto;
    }
    
    .delete-dialog-header,
    .delete-dialog-content,
    .delete-dialog-footer {
        padding: 16px !important;
    }
    
    .delete-warning-card {
        padding: 16px !important;
    }
}

/* Simple Context Selector Styling */
.context-selector-container {
    display: flex;
    gap: var(--lumo-space-s);
    align-items: center;
    padding: var(--lumo-space-xs);
    background-color: transparent;
    border-radius: var(--lumo-border-radius-s);
}

.context-selector {
    min-width: 150px;
    font-size: var(--lumo-font-size-s);
}

.context-selector::part(input-field) {
    background-color: var(--lumo-base-color);
    border: 1px solid var(--lumo-contrast-20pct);
    border-radius: var(--lumo-border-radius-s);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    height: var(--lumo-size-s);
    font-size: var(--lumo-font-size-s);
}

.context-selector::part(input-field):hover {
    border-color: var(--lumo-primary-color-50pct);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.context-selector[focused]::part(input-field) {
    border-color: var(--lumo-primary-color);
    box-shadow: 0 0 0 2px var(--lumo-primary-color-50pct);
}

.context-selector::part(toggle-button) {
    color: var(--lumo-secondary-text-color);
}

.context-selector::part(value) {
    font-size: var(--lumo-font-size-s);
    color: var(--lumo-body-text-color);
}

/* Simple labels */
.context-selector-tenant::before {
    content: "SPÓŁKA";
    position: absolute;
    top: -18px;
    left: 0;
    font-size: var(--lumo-font-size-xs);
    color: var(--lumo-secondary-text-color);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.context-selector-institution::before {
    content: "ZAKŁAD";
    position: absolute;
    top: -18px;
    left: 0;
    font-size: var(--lumo-font-size-xs);
    color: var(--lumo-secondary-text-color);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.context-selector-billing::before {
    content: "ROZLICZENIOWY";
    position: absolute;
    top: -18px;
    left: 0;
    font-size: var(--lumo-font-size-xs);
    color: var(--lumo-secondary-text-color);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.context-selector-tenant,
.context-selector-institution,
.context-selector-billing {
    position: relative;
    padding-top: var(--lumo-space-m);
}

/* Responsive Design */
@media (max-width: 1200px) {
    .context-selector {
        min-width: 130px;
    }
}

@media (max-width: 960px) {
    .context-selector {
        min-width: 120px;
    }
    
    .context-selector-container {
        gap: var(--lumo-space-xs);
    }
}

@media (max-width: 768px) {
    .context-selector {
        min-width: 100px;
    }
    
    .context-selector-billing::before {
        content: "OKRES";
    }
}

@media (max-width: 600px) {
    .context-selector-container {
        flex-direction: column;
        align-items: stretch;
        gap: var(--lumo-space-xs);
        padding: var(--lumo-space-xs);
        background-color: var(--lumo-contrast-5pct);
        border-radius: var(--lumo-border-radius-s);
    }
    
    .context-selector {
        width: 100%;
        min-width: auto;
    }
}

/* Open New Billing Period Dialog Styles */
.billing-period-dialog {
    --lumo-border-radius-l: 16px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
    border: 1px solid var(--lumo-contrast-10pct);
    max-width: 600px;
    width: 90vw;
}

.billing-period-dialog-header {
    background: linear-gradient(135deg, var(--lumo-primary-color) 0%, var(--lumo-primary-color-50pct) 100%);
    color: var(--lumo-base-color);
    border-radius: 16px 16px 0 0;
    padding: var(--lumo-space-l);
    margin: 0;
    border-bottom: none;
}

.billing-period-dialog-title {
    font-size: var(--lumo-font-size-xl);
    font-weight: 600;
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--lumo-space-s);
}

.billing-period-dialog-title vaadin-icon {
    font-size: 1.5em;
}

.billing-period-context-section {
    background: linear-gradient(135deg, var(--lumo-primary-color-10pct) 0%, var(--lumo-primary-color-5pct) 100%);
    border: 1px solid var(--lumo-primary-color-20pct);
    border-radius: 12px;
    padding: var(--lumo-space-m);
    margin-bottom: var(--lumo-space-m);
    position: relative;
    overflow: hidden;
}

.billing-period-context-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--lumo-primary-color) 0%, var(--lumo-primary-color-50pct) 100%);
}

.billing-period-context-info {
    display: flex;
    flex-direction: column;
    gap: var(--lumo-space-xs);
}

.billing-period-context-item {
    display: flex;
    align-items: center;
    gap: var(--lumo-space-s);
    font-size: var(--lumo-font-size-m);
}

.billing-period-context-icon {
    color: var(--lumo-primary-color);
    font-size: 1.2em;
    min-width: 20px;
}

.billing-period-context-label {
    font-weight: 500;
    color: var(--lumo-secondary-text-color);
    min-width: 80px;
}

.billing-period-context-value {
    font-weight: 600;
    color: var(--lumo-primary-text-color);
}

.billing-period-warning-section {
    background: linear-gradient(135deg, var(--lumo-error-color-10pct) 0%, var(--lumo-error-color-5pct) 100%);
    border: 2px solid var(--lumo-error-color-50pct);
    border-radius: 12px;
    padding: var(--lumo-space-m);
    margin-bottom: var(--lumo-space-m);
    position: relative;
    overflow: hidden;
    animation: pulse-warning-subtle 3s infinite;
}

@keyframes pulse-warning-subtle {
    0%, 100% { 
        border-color: var(--lumo-error-color-50pct);
        box-shadow: 0 0 0 0 rgba(244, 67, 54, 0.1);
    }
    50% { 
        border-color: var(--lumo-error-color);
        box-shadow: 0 0 0 4px rgba(244, 67, 54, 0.1);
    }
}

.billing-period-warning-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--lumo-error-color) 0%, var(--lumo-error-color-50pct) 100%);
}

.billing-period-warning-header {
    display: flex;
    align-items: center;
    gap: var(--lumo-space-s);
    margin-bottom: var(--lumo-space-s);
}

.billing-period-warning-icon {
    color: var(--lumo-error-color);
    font-size: 1.5em;
    animation: shake 2s infinite;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-2px); }
    20%, 40%, 60%, 80% { transform: translateX(2px); }
}

.billing-period-warning-title {
    font-size: var(--lumo-font-size-l);
    font-weight: 700;
    color: var(--lumo-error-color);
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.billing-period-warning-description {
    color: var(--lumo-error-text-color);
    font-size: var(--lumo-font-size-m);
    font-weight: 500;
    margin: 0;
    line-height: 1.4;
}

.billing-period-info-section {
    background: linear-gradient(135deg, var(--lumo-contrast-5pct) 0%, var(--lumo-base-color) 100%);
    border: 1px solid var(--lumo-contrast-20pct);
    border-radius: 12px;
    padding: var(--lumo-space-m);
    margin-bottom: var(--lumo-space-m);
}

.billing-period-info-title {
    font-size: var(--lumo-font-size-m);
    font-weight: 600;
    color: var(--lumo-primary-text-color);
    margin: 0 0 var(--lumo-space-s) 0;
    display: flex;
    align-items: center;
    gap: var(--lumo-space-s);
}

.billing-period-info-title vaadin-icon {
    color: var(--lumo-primary-color);
}

.billing-period-consequences-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--lumo-space-s);
}

.billing-period-consequence-item {
    display: flex;
    align-items: flex-start;
    gap: var(--lumo-space-s);
    padding: var(--lumo-space-s);
    background-color: var(--lumo-base-color);
    border-radius: 8px;
    border-left: 3px solid var(--lumo-primary-color-50pct);
    transition: all 0.2s ease;
}

.billing-period-consequence-item:hover {
    background-color: var(--lumo-primary-color-5pct);
    border-left-color: var(--lumo-primary-color);
    transform: translateX(2px);
}

.billing-period-consequence-icon {
    color: var(--lumo-primary-color);
    font-size: 1.1em;
    margin-top: 2px;
    min-width: 16px;
}

.billing-period-consequence-text {
    color: var(--lumo-body-text-color);
    font-size: var(--lumo-font-size-s);
    line-height: 1.4;
    margin: 0;
}

.billing-period-form-section {
    background: linear-gradient(135deg, var(--lumo-base-color) 0%, var(--lumo-contrast-5pct) 100%);
    border: 1px solid var(--lumo-contrast-20pct);
    border-radius: 12px;
    padding: var(--lumo-space-m);
    margin-bottom: var(--lumo-space-m);
}

.billing-period-form-field {
    margin: 0;
}

.billing-period-form-field vaadin-text-field {
    width: 100%;
}

.billing-period-form-field vaadin-text-field::part(input-field) {
    background-color: var(--lumo-base-color);
    border: 2px solid var(--lumo-contrast-20pct);
    border-radius: 8px;
    transition: all 0.2s ease;
}

.billing-period-form-field vaadin-text-field:hover::part(input-field) {
    border-color: var(--lumo-primary-color-50pct);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.billing-period-form-field vaadin-text-field[focused]::part(input-field) {
    border-color: var(--lumo-primary-color);
    box-shadow: 0 0 0 3px var(--lumo-primary-color-50pct);
}

.billing-period-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--lumo-space-m);
    padding: var(--lumo-space-m);
    background: linear-gradient(135deg, var(--lumo-contrast-5pct) 0%, var(--lumo-contrast-10pct) 100%);
    border-radius: 0 0 16px 16px;
    border-top: 1px solid var(--lumo-contrast-10pct);
}

.billing-period-button-cancel {
    background-color: var(--lumo-contrast-10pct);
    color: var(--lumo-body-text-color);
    border: 1px solid var(--lumo-contrast-20pct);
    border-radius: 8px;
    padding: var(--lumo-space-s) var(--lumo-space-l);
    font-weight: 500;
    transition: all 0.2s ease;
}

.billing-period-button-cancel:hover {
    background-color: var(--lumo-contrast-20pct);
    border-color: var(--lumo-contrast-30pct);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.billing-period-button-confirm {
    background: linear-gradient(135deg, var(--lumo-error-color) 0%, var(--lumo-error-color-50pct) 100%);
    color: var(--lumo-base-color);
    border: none;
    border-radius: 8px;
    padding: var(--lumo-space-s) var(--lumo-space-l);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
}

.billing-period-button-confirm::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.billing-period-button-confirm:hover::before {
    left: 100%;
}

.billing-period-button-confirm:hover {
    background: linear-gradient(135deg, var(--lumo-error-color-50pct) 0%, var(--lumo-error-color) 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(244, 67, 54, 0.3);
}

.billing-period-button-confirm:disabled {
    background: var(--lumo-contrast-20pct);
    color: var(--lumo-disabled-text-color);
    transform: none;
    box-shadow: none;
}

.billing-period-button-confirm:disabled::before {
    display: none;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .billing-period-dialog {
        width: 95vw;
        max-width: 95vw;
    }
    
    .billing-period-actions {
        flex-direction: column;
        gap: var(--lumo-space-s);
    }
    
    .billing-period-button-cancel,
    .billing-period-button-confirm {
        width: 100%;
        justify-content: center;
    }
    
    .billing-period-context-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--lumo-space-xs);
    }
    
    .billing-period-context-label {
        min-width: auto;
    }
}

@media (max-width: 480px) {
    .billing-period-dialog-header,
    .billing-period-info-section,
    .billing-period-warning-section,
    .billing-period-context-section,
    .billing-period-form-section {
        padding: var(--lumo-space-m);
    }
    
    .billing-period-dialog-title {
        font-size: var(--lumo-font-size-l);
    }
    
    .billing-period-warning-title {
        font-size: var(--lumo-font-size-m);
    }
}
