/*
  Stripe/SaaS-like UI for Django Admin TabularInline (OrderLine).
  - Purely presentational: no business logic, no backend coupling.
  - Scoped via the inline's `classes` (see orders/admin.py).
*/

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) {
  --ol-accent: #ff8c00;
  --ol-row-bg: #0b0b0b;
  --ol-row-bg-hover: #101010;
  --ol-border: #222;
  --ol-border-strong: rgba(255, 140, 0, 0.35);
  --ol-text-dim: rgba(255, 255, 255, 0.72);
  --ol-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}

/* Make the table feel like "rows as cards" */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) {
  border: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  overflow-x: auto;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular {
  border-collapse: separate;
  border-spacing: 0 10px;
  width: 100%;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular thead th {
  background: transparent !important;
  border: 0 !important;
  color: var(--ol-text-dim) !important;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0 10px 6px !important;
  white-space: nowrap;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row {
  transition: outline-color 120ms ease, transform 120ms ease;
  outline: 1px solid transparent;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row:hover,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row:focus-within {
  outline-color: var(--ol-border-strong);
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row:focus-within {
  transform: translateY(-1px);
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row td {
  background: var(--ol-row-bg) !important;
  border-top: 1px solid var(--ol-border) !important;
  border-bottom: 1px solid var(--ol-border) !important;
  padding: 10px !important;
  vertical-align: top;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row:hover td,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row:focus-within td {
  background: var(--ol-row-bg-hover) !important;
}

/* Rounded "card" edges per row */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row td:first-child {
  border-left: 1px solid var(--ol-border) !important;
  border-top-left-radius: 12px;
  border-bottom-left-radius: 12px;
}
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row td:last-child {
  border-right: 1px solid var(--ol-border) !important;
  border-top-right-radius: 12px;
  border-bottom-right-radius: 12px;
}

/* Keep Django's "original" column unobtrusive, but don't hide hidden inputs */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.original {
  color: rgba(255, 255, 255, 0.5) !important;
  font-size: 11px;
  max-width: 200px;
}
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.original p {
  margin: 0 !important;
}

/* Unified controls (without changing widths set by widgets/styles) */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) input,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) select,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) textarea {
  background: #0f0f0f !important;
  border: 1px solid #2a2a2a !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 7px 10px !important;
  min-height: 34px;
  box-sizing: border-box;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) textarea {
  min-height: 38px;
  resize: vertical;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) input:focus,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) select:focus,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) textarea:focus {
  outline: none !important;
  border-color: rgba(255, 140, 0, 0.6) !important;
  box-shadow: 0 0 0 3px rgba(255, 140, 0, 0.12) !important;
}

/* Subtle per-row feedback when the user edits something */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tbody tr.form-row.is-dirty td:first-child {
  box-shadow: inset 3px 0 0 0 var(--ol-accent);
}

/* Readonly totals: visual hierarchy + numeric alignment */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td .readonly {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  margin: 0 !important;
  padding: 8px 10px !important;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td .readonly.is-preview {
  cursor: help;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .ol-muted {
  color: rgba(255, 255, 255, 0.65) !important;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .ol-preview-badge {
  margin-left: 8px;
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid rgba(255, 140, 0, 0.35);
  background: rgba(255, 140, 0, 0.12);
  color: rgba(255, 140, 0, 0.95) !important;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.04em;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-unit_price_calc_display .readonly {
  border-color: rgba(255, 140, 0, 0.2) !important;
  background: rgba(255, 140, 0, 0.06) !important;
  color: rgba(255, 140, 0, 0.92) !important;
  font-weight: 700;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-line_base_total_display .readonly {
  border-color: rgba(255, 140, 0, 0.35) !important;
  background: rgba(255, 140, 0, 0.1) !important;
  color: #ffb35c !important;
  font-weight: 800;
}

/* Delete column: keep it tidy */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.delete {
  text-align: center;
  width: 52px;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .ol-delete-btn {
  background: #9f1d1d;
  color: #fff;
  border: 1px solid #c43a3a;
  border-radius: 8px;
  width: 28px;
  height: 28px;
  line-height: 24px;
  font-size: 20px;
  cursor: pointer;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .ol-delete-btn:hover {
  background: #bf2a2a;
}

/* Add-row: keep it clean and consistent */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tr.add-row td {
  background: transparent !important;
  border: 0 !important;
  padding: 6px 0 0 !important;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tr.add-row a {
  display: inline-block;
  padding: 8px 12px;
  border-radius: 10px;
  background: rgba(255, 140, 0, 0.12);
  border: 1px solid rgba(255, 140, 0, 0.25);
  color: #ffb35c !important;
  font-weight: 700;
  text-decoration: none !important;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular tr.add-row a:hover {
  background: rgba(255, 140, 0, 0.18);
  border-color: rgba(255, 140, 0, 0.4);
}

/* =========================================================
   Single Field Layout (Simplified Modelo/Acabado)
   - Updated to stack elements and hide the second column
   ========================================================= */

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-catalog_model {
  min-width: 100px; /* Reduced since it's a single field now */
}

/* --- AJUSTE UNIFICADO: PERNIO, MANO Y CERRADURA --- */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-pernio,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-mano,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-hand,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-cerradura,
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) table.tabular td.field-lock {
  width: 90px !important;
  min-width: 90px !important;
  max-width: 110px !important;
}

/* Forzamos que los inputs/selects dentro de estos campos técnicos sean consistentes */
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) td.field-pernio :is(input, select),
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) td.field-mano :is(input, select),
:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) td.field-cerradura :is(input, select) {
  width: 100% !important;
  min-width: 0 !important;
  text-align: center;
  text-transform: uppercase;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-variant-select-hidden {
  display: none !important;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-variant-picker {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-vp-col:last-child {
  display: none !important; /* Hides the second column (Acabado select) */
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-vp-col {
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-vp-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ol-text-dim) !important;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-vp-search {
  width: 100%;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-vp-search:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

:is(fieldset.module, .inline-group):is(.orderline-inline, .stripe-inline) .erp-vp-search::placeholder {
  color: rgba(255, 255, 255, 0.55);
}
