/*
 * payment.css — supplement to pel-modern.css for the payment wizard
 * (Reference / Identity / Agreement screens).
 *
 * Folded from the claudedesign bundle's app.css. Uses ONLY existing --pel-*
 * tokens — no new colours, no new type. The prototype's #root and CSS
 * text-lockup logo rules were dropped: the real app pins its footer via
 * `body { display:flex }` in pel-modern.css and uses the real logo.svg <img>.
 * Loaded only on the wizard pages (gated by $pel_wizard_css in header.php).
 */

/* ---- Page header row (title + language) ---- */
.pel-pagehead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.pel-pagehead h1 { flex: 1 1 auto; margin-bottom: 0; }

/* language switch — simple text control, green accent like links.
   Rendered as <a> links (server-side i18n via ?lang=xx) rather than the
   prototype's <button>s, so the selectors cover both. */
.pel-lang { display: inline-flex; align-items: center; gap: 0; flex-shrink: 0; }
.pel-lang button,
.pel-lang a {
  border: 1px solid var(--pel-border);
  background: var(--pel-white);
  color: var(--pel-mid);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  padding: 0.3rem 0.7rem;
  cursor: pointer;
  margin: 0 0 0 -1px;
  text-decoration: none;
  line-height: 1.2;
}
.pel-lang button:first-child,
.pel-lang a:first-child { border-radius: 4px 0 0 4px; margin-left: 0; }
.pel-lang button:last-child,
.pel-lang a:last-child  { border-radius: 0 4px 4px 0; }
.pel-lang button.active,
.pel-lang a.active {
  background: var(--pel-green);
  border-color: var(--pel-green);
  color: var(--pel-white);
  position: relative; z-index: 1;
}
.pel-lang button:not(.active):hover,
.pel-lang a:not(.active):hover { background: var(--pel-green-l); color: var(--pel-green-d); text-decoration: none; }

/* ---- Stepper: extends #fil_ariane (existing breadcrumb) ---- */
#fil_ariane {
  border-collapse: separate;
  border-spacing: 5px 0;
  table-layout: fixed;
  margin: 0.25rem 0 1.5rem;
}
#fil_ariane td {
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.6rem 0.4rem;
  border-radius: 3px;
  border: 1px solid var(--pel-border);
  position: relative;
}
#fil_ariane td .stepnum {
  display: inline-grid; place-items: center;
  width: 18px; height: 18px; border-radius: 50%;
  font-size: 0.7rem; margin-right: 0.4rem;
  vertical-align: middle;
  background: var(--pel-border); color: var(--pel-white);
}
/* upcoming */
#fil_ariane td.free { background: var(--pel-light); color: var(--pel-muted); }
/* current — charcoal (structure) */
#fil_ariane td.full {
  background: var(--pel-struct); color: var(--pel-white); border-color: var(--pel-struct);
}
#fil_ariane td.full .stepnum { background: var(--pel-white); color: var(--pel-struct); }
/* completed — green accent (10%) */
#fil_ariane td.done { background: var(--pel-green-l); color: var(--pel-green-d); border-color: #CDE8CA; }
#fil_ariane td.done .stepnum { background: var(--pel-green); color: var(--pel-white); }

@media (max-width: 640px) {
  #fil_ariane td { font-size: 0; padding: 0.5rem 0; }
  #fil_ariane td .stepnum { margin: 0; font-size: 0.7rem; }
  #fil_ariane td.full { font-size: 0.72rem; }
  #fil_ariane td.full .stepnum { margin-right: 0.4rem; }
}

/* ---- Wizard layout ---- */
.pel-wrap { max-width: 940px; margin: 0 auto; }

.field-row { margin-bottom: 1.1rem; }
.field-row label.lbl {
  display: block; font-weight: 600; color: var(--pel-dark);
  font-size: 0.9rem; margin-bottom: 0.35rem;
}
.field-row label.lbl .req { color: var(--pel-green-d); }
.field-row .hint { color: var(--pel-muted); font-size: 0.8rem; margin: 0.35rem 0 0; }
.field-row input.invalid,
.field-row select.invalid { border-color: var(--pel-error); box-shadow: 0 0 0 3px rgba(192,57,43,0.14); }
.field-row input.full-w, .field-row textarea.full-w { max-width: 100%; }

.intro-p { color: var(--pel-mid); font-size: 0.9rem; line-height: 1.55; margin: 0 0 1rem; }
.intro-p b { color: var(--pel-dark); }

/* checkbox row */
.pel-check {
  display: flex; gap: 0.6rem; align-items: flex-start;
  padding: 0.7rem 0.85rem; border: 1px solid var(--pel-border);
  border-radius: 4px; background: var(--pel-light); cursor: pointer;
}
.pel-check.on { border-color: var(--pel-green); background: var(--pel-green-l); }
.pel-check.invalid { border-color: var(--pel-error); }
.pel-check input { width: 18px; height: 18px; margin: 1px 0 0; accent-color: var(--pel-green); flex-shrink: 0; cursor: pointer; }
.pel-check span { font-size: 0.85rem; color: var(--pel-text); line-height: 1.45; }
.pel-check span b { color: var(--pel-dark); }

/* amounts table tweaks */
table.pel-amounts { margin: 0.5rem 0 0; }
table.pel-amounts td { font-size: 0.9rem; }
table.pel-amounts td.amt { text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
table.pel-amounts td.full { font-weight: 700; }

/* button row */
.pel-actions {
  display: flex; align-items: center; gap: 0.75rem;
  margin-top: 1.25rem; padding-top: 1rem; border-top: 1px solid var(--pel-border);
}
.pel-actions .spacer { flex: 1; }
.pel-actions.center { justify-content: center; border-top: 0; padding-top: 0; }

/* ---- Order summary panel ---- */
.pel-summary { position: sticky; top: 1rem; }
.pel-summary fieldset { background: var(--pel-white); }
.pel-summary h2 { margin-top: 0; }
.pel-summary .desc { color: var(--pel-mid); font-size: 0.82rem; line-height: 1.5; margin: 0 0 0.85rem; }
.pel-summary .trust { margin-top: 0.85rem; border-top: 1px solid var(--pel-border); padding-top: 0.7rem; }
.pel-summary .trust div {
  display: flex; align-items: center; gap: 0.45rem;
  font-size: 0.78rem; color: var(--pel-mid); margin-bottom: 0.35rem;
}
.pel-summary .trust svg { width: 14px; height: 14px; color: var(--pel-green-d); flex-shrink: 0; }
.pel-summary .trust b { color: var(--pel-dark); }

/* event banner (uses h2 styling) */
.pel-event { display: flex; gap: 0.85rem; align-items: center; margin-bottom: 1rem; }
.pel-event__thumb {
  width: 46px; height: 46px; flex-shrink: 0; border-radius: 4px;
  background: var(--pel-green-l); border: 1px solid #CDE8CA;
  display: grid; place-items: center; color: var(--pel-green-d);
}
.pel-event__thumb svg { width: 22px; height: 22px; }
.pel-event__meta .k { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.6px; color: var(--pel-green-d); font-weight: 700; }
.pel-event__meta h3 { font-size: 1.02rem; color: var(--pel-dark); margin: 0.15rem 0; font-weight: 700; }
.pel-event__meta p { font-size: 0.82rem; color: var(--pel-mid); margin: 0; line-height: 1.45; }

/* review (agreement) */
.pel-review { width: 100%; }
.pel-review th { width: 38%; vertical-align: top; }
.pel-review td { font-weight: 600; color: var(--pel-dark); }

.pel-securenote {
  display: flex; gap: 0.6rem; align-items: flex-start;
  background: var(--pel-light); border: 1px solid var(--pel-border);
  border-left: 3px solid var(--pel-green); border-radius: 4px;
  padding: 0.75rem 0.9rem; font-size: 0.85rem; color: var(--pel-mid); line-height: 1.5;
  margin: 1rem 0;
}
.pel-securenote svg { width: 17px; height: 17px; color: var(--pel-green-d); flex-shrink: 0; margin-top: 1px; }
.pel-securenote b { color: var(--pel-dark); }

/* info note above the optional "request an invoice" checkbox — discreet, same
   visual language as .pel-securenote (light bg, green accent, small muted text) */
.pel-invoice-note {
  display: flex; gap: 0.55rem; align-items: flex-start;
  background: var(--pel-light); border: 1px solid var(--pel-border);
  border-left: 3px solid var(--pel-green); border-radius: 4px;
  padding: 0.65rem 0.85rem; font-size: 0.8rem; color: var(--pel-mid); line-height: 1.5;
  margin: 0 0 0.8rem;
}
.pel-invoice-note .bi { color: var(--pel-green-d); font-size: 1rem; flex-shrink: 0; line-height: 1.4; }

/* result status block (payok.php — single Worldline return page) */
.pel-result {
  display: flex; gap: 0.6rem; align-items: flex-start;
  background: var(--pel-light); border: 1px solid var(--pel-border);
  border-radius: 4px; padding: 0.75rem 0.9rem;
  font-size: 0.9rem; color: var(--pel-mid); line-height: 1.55;
  margin: 0 0 1rem;
}
.pel-result svg { width: 20px; height: 20px; flex-shrink: 0; margin-top: 1px; }
.pel-result b { color: var(--pel-dark); }
.pel-result.ok { border-left: 3px solid var(--pel-green); }
.pel-result.ok svg { color: var(--pel-green-d); }
.pel-result.ko { border-left: 3px solid var(--pel-error); }
.pel-result.ko svg { color: var(--pel-error); }

.pel-footnote { color: var(--pel-muted); font-size: 0.78rem; text-align: center; line-height: 1.55; margin: 1rem auto 0; max-width: 620px; }

/* screen transition */
.screen-enter { animation: pelIn 0.32s ease both; }
@keyframes pelIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .screen-enter { animation: none; } }

.mt0 { margin-top: 0; }
