@charset "utf-8";
/* ==========================================================================
   Labeljoy Shop — Main Stylesheet
   Brand colors: #474F55 (dark) · #EB711E (orange) · gradient #EF8810→#EB711E
   ========================================================================== */

/* ── CSS Variables ───────────────────────────────────────────────────────── */
:root {
  --lj-dark:      #474F55;
  --lj-dark-rgb:  71, 79, 85;
  --lj-orange:    #EB711E;
  --lj-orange-dk: #c75a10;
  --lj-orange-lt: #EF8810;
  --lj-light:     #f8f9fa;
  --lj-border:    #dee2e6;
  --lj-text:      #333;
  --lj-muted:     #6c757d;
  --lj-green:     #198754;
  --lj-white:     #ffffff;
  --lj-shadow:    0 1px 4px rgba(0,0,0,.06);
  --lj-shadow-md: 0 2px 12px rgba(0,0,0,.08);
  --lj-radius:    10px;
}

/* ── Base Reset ──────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Open Sans', 'Segoe UI', Arial, sans-serif;
  background: var(--lj-light);
  color: var(--lj-text);
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
}

h2 {
  color: var(--lj-dark);
  font-weight: 700;
  font-size: 1.45rem;
  margin: 0 0 1rem;
}
h3 {
  color: var(--lj-dark);
  font-weight: 600;
  font-size: 1.05rem;
  margin: 1.5rem 0 .6rem;
}
p { margin: 0 0 .75rem; }

a { color: var(--lj-orange); text-decoration: none; }
a:hover { color: var(--lj-orange-dk); text-decoration: underline; }

mark {
  background: #fff3cd;
  padding: 1px 5px;
  border-radius: 3px;
  font-size: .9em;
}

/* ── Navbar ──────────────────────────────────────────────────────────────── */
.lj-navbar {
  background: var(--lj-white);
  border-bottom: 1px solid var(--lj-border);
  padding: 12px 20px;
  box-shadow: var(--lj-shadow);
  position: sticky;
  top: 0;
  z-index: 100;
}
.lj-navbar-inner {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.lj-navbar-brand img { height: 38px; display: block; }
.lj-secure-badge {
  color: var(--lj-muted);
  font-size: .82rem;
  display: flex;
  align-items: center;
  gap: 6px;
}
.lj-secure-badge i { color: var(--lj-green); font-size: .95rem; }

/* ── Step Indicator ──────────────────────────────────────────────────────── */
.lj-steps-bar {
  background: var(--lj-white);
  border-bottom: 1px solid var(--lj-border);
  padding: 14px 20px;
}
.lj-steps {
  max-width: 520px;
  margin: 0 auto;
  display: flex;
  align-items: center;
}
.lj-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  position: relative;
}
.lj-step-line {
  flex: 1;
  height: 2px;
  background: var(--lj-border);
  transition: background .3s;
}
.lj-step-line.done { background: var(--lj-orange); }
.lj-step-circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--lj-light);
  border: 2px solid var(--lj-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .78rem;
  font-weight: 700;
  color: var(--lj-muted);
  z-index: 1;
  transition: all .3s;
}
.lj-step.done .lj-step-circle {
  background: var(--lj-orange);
  border-color: var(--lj-orange);
  color: #fff;
}
.lj-step.active .lj-step-circle {
  background: var(--lj-white);
  border-color: var(--lj-orange);
  color: var(--lj-orange);
  box-shadow: 0 0 0 4px rgba(235,113,30,.15);
}
.lj-step.fail .lj-step-circle {
  background: #dc3545;
  border-color: #dc3545;
  color: #fff;
}
.lj-step-label {
  font-size: .68rem;
  margin-top: 5px;
  color: var(--lj-muted);
  text-align: center;
  white-space: nowrap;
}
.lj-step.active .lj-step-label,
.lj-step.done .lj-step-label { color: var(--lj-dark); font-weight: 600; }

/* ── Main Content Wrapper ────────────────────────────────────────────────── */
.lj-main {
  max-width: 960px;
  margin: 0 auto;
  padding: 28px 16px 64px;
}

/* ── Error / Notification ────────────────────────────────────────────────── */
.tt-notification.error {
  background: #fff5f5;
  border: 1px solid #f5c6cb;
  border-left: 4px solid #dc3545;
  border-radius: var(--lj-radius);
  padding: 14px 18px;
  margin-bottom: 20px;
  color: #721c24;
}
.tt-notification.error strong { display: block; margin-bottom: 4px; }

/* ── Card wrapper ────────────────────────────────────────────────────────── */
.bgData {
  background: var(--lj-white);
  border: 1px solid var(--lj-border);
  border-radius: var(--lj-radius);
  padding: 0;
  margin-bottom: 24px;
  box-shadow: var(--lj-shadow);
  overflow: hidden;
}
.bgData > div { padding: 0; }

/* ── Product Table (cartTable) ───────────────────────────────────────────── */
.cartTable {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--lj-white);
  border: 1px solid var(--lj-border);
  border-radius: var(--lj-radius);
  margin-bottom: 20px;
  overflow: hidden;
  box-shadow: var(--lj-shadow);
}
/* Header rows with gray bg */
.cartTable tr[style*="background-color: #EEEEEE"] th,
.cartTable tr[style*="background-color:#EEEEEE"] th,
.cartTable tr[style*="background-color: #EEEEEE"] td,
.cartTable tr[style*="background-color:#EEEEEE"] td {
  background: var(--lj-light) !important;
  color: var(--lj-muted);
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 10px 14px !important;
  border-bottom: 1px solid var(--lj-border);
}
.cartTable th {
  padding: 10px 14px;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--lj-muted);
  border-bottom: 2px solid var(--lj-border);
  text-align: left;
  border: none;
}
.cartTable th[align="right"],
.cartTable td[align="right"] { text-align: right; }

.cartTable td {
  padding: 14px;
  border: none;
  border-bottom: 1px solid rgba(0,0,0,.06);
  vertical-align: middle;
}
.cartTable tr:last-child td { border-bottom: none; }

/* Product rows */
.cartTable .prLine td { background: #fff; transition: background .15s; }
.cartTable .prLine:hover td { background: #fafcff; }

/* Selected product row highlight (modern CSS) */
.cartTable .prLine:has(input:checked) td,
.cartTable .prLine:has(input:checked) + .SmallHint td,
.cartTable .prLine:has(input:checked) + .prLineSeat td,
.cartTable .prLine:has(input:checked) + .prLineSeat + .SmallHint td{
  background: #fffaf6;
  border-left: none;
  border-right: none;
}
.cartTable .prLine td,
.cartTable .prLineSeat td{
  border-bottom: none
}
.cartTable .prLine td:first-child,
.cartTable .SmallHint td:first-child {
  border-left: 3px solid transparent;
}
.cartTable .prLine td:last-child,
.cartTable .SmallHint td:last-child {
  border-right: 3px solid transparent;
}
.cartTable .prLine:has(input:checked) td:first-child,
.cartTable .prLine:has(input:checked) + .SmallHint td:first-child:first-child,
.cartTable .prLine:has(input:checked) + .prLineSeat td:first-child,
.cartTable .prLine:has(input:checked) + .prLineSeat + .SmallHint td:first-child {
  border-left: 3px solid var(--lj-orange);
}
.cartTable .prLine:has(input:checked) td:last-child,
.cartTable .prLine:has(input:checked) + .SmallHint td:last-child,
.cartTable .prLine:has(input:checked) + .prLineSeat td:last-child,
.cartTable .prLine:has(input:checked) + .prLineSeat + .SmallHint td:last-child {
  border-right: 3px solid var(--lj-orange);
}

/* Product description — inline with product name row */
.cartTable .prDetails {
  display: block;
  color: var(--lj-muted);
  margin-top: 4px;
  font-weight: 400;
  line-height: 1.4;
}

/* Product description hints (legacy fallback) */
.cartTable .SmallHint { color: var(--lj-muted); }
.cartTable .SmallHint td {
  font-size: .82em;
  padding: 2px 14px 12px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

/* Coupon / total row */
.cartTable tr:has(#disc0unt_c0de) td,
.cartTable tr:has(.txttotal) td {
  background: var(--lj-light);
  padding: 12px 14px;
}

/* ── Coupon field ────────────────────────────────────────────────────────── */
.txttotal {
  background: transparent !important;
  border: none !important;
  font-weight: 700;
  font-size: 1.1rem;
  text-align: right;
  color: var(--lj-dark);
  padding: 0;
  width: auto;
  box-shadow: none !important;
}
#disc0unt_c0de {
  max-width: 200px;
  width: 200px;
}
#coupon_message {
  color: var(--lj-orange);
  font-size: .82rem;
  font-weight: 600;
}

/* ── Data Tables (customer info) ─────────────────────────────────────────── */
.dataTable,
.dataTable1 {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}
.dataTable td,
.dataTable1 td {
  padding: 10px 16px;
  vertical-align: middle;
  border: none;
}
.dataTable tr.borderBottom > td,
.dataTable1 tr.borderBottom > td {
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.dataTable tr td:first-child,
.dataTable1 tr td:first-child {
  width: 190px;
  color: var(--lj-muted);
  font-size: .88rem;
  white-space: nowrap;
  padding-right: 8px;
}
/* Email highlight row */
td[style*="background-color:#c7d9b2"],
td[style*="background-color: #c7d9b2"] {
  background: #f4fbee !important;
  border-radius: 4px;
}
/* Bordes bottom in dataTable */
.dataTable td { border-bottom: 1px solid rgba(0,0,0,.05); }

/* ── Form Inputs ─────────────────────────────────────────────────────────── */
input[type='text'],
input[type='email'],
input[type='tel'],
input[type='number'],
select,
input.form {
  display: inline-block;
  border: 1px solid #ccc;
  border-radius: 6px;
  padding: 7px 11px;
  font-size: .88rem;
  color: var(--lj-text);
  background: var(--lj-white);
  font-family: inherit;
  transition: border-color .2s, box-shadow .2s;
  line-height: 1.4;
}
input[type='text']:focus,
input[type='email']:focus,
input[type='tel']:focus,
input[type='number']:focus,
select:focus {
  outline: none;
  border-color: var(--lj-orange);
  box-shadow: 0 0 0 3px rgba(235,113,30,.15);
}
input[disabled],
input[disabled='disabled'] {
  background-color: #f4f4f4 !important;
  cursor: not-allowed;
  color: #888;
}
input::placeholder,
textarea::placeholder { font-style: italic; color: #bbb; }

/* Full-width inputs inside data tables */
.cartTable input[type='text'],
.dataTable input[type='text'],
.dataTable1 input[type='text'],
.cartTable select,
.dataTable select,
.dataTable1 select {
  width: 100%;
  background-color: var(--lj-white);
}

select {
  padding: 7px 30px 7px 11px;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23474F55' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 9px center;
  background-size: 12px;
  cursor: pointer;
}

/* Checkboxes and radios */
input[type='checkbox'],
input[type='radio'] {
  width: 17px;
  height: 17px;
  accent-color: var(--lj-orange);
  cursor: pointer;
  vertical-align: middle;
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
input[type='submit'],
input[type='button'],
input[type='reset'],
button {
  border: 1px solid transparent;
  border-radius: 6px;
  padding: 9px 20px;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: background .2s, transform .1s, box-shadow .2s;
  letter-spacing: .01em;
  display: inline-block;
}
/* Green/Orange CTA button */
.button.green,
.button.green:visited,
input.button.green,
input.nextStep.button.green {
  background: linear-gradient(135deg, var(--lj-orange-lt) 0%, var(--lj-orange) 100%) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: 0 2px 8px rgba(235,113,30,.3);
}
.button.green:hover,
.button.green:focus,
.button.green:active,
input.button.green:hover,
input.nextStep.button.green:hover {
  background: var(--lj-orange-dk) !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(235,113,30,.38);
}
/* Silver/Back button */
.button.silver,
.button.silver:visited,
input.button.silver {
  background: #e9ecef !important;
  color: var(--lj-dark) !important;
  border: 1px solid var(--lj-border) !important;
  box-shadow: none;
}
.button.silver:hover,
.button.silver:focus,
.button.silver:active,
input.button.silver:hover {
  background: #dde0e3 !important;
  color: var(--lj-dark) !important;
}
/* Next step button size */
.nextStep {
  font-size: .92rem;
  font-weight: 700;
  padding: 10px 26px;
}
/* Action row alignment */
.dataTable1 tr:has([name="Submit"]) td:first-child,
.dataTable1 tr:has([name="Back"]) td:first-child { text-align: right; }

/* ── Italian invoice section ─────────────────────────────────────────────── */
.fatturazione td,
tr.fatturazione td { background: #fafafa; }

/* ── Tables inside .bgData card ──────────────────────────────────────────── */
/* When cartTable sits inside bgData, remove its own card decoration */
.bgData .cartTable {
  border: none;
  box-shadow: none;
  border-radius: 0;
  margin-bottom: 0;
}
.bgData form { border-top: 2px solid var(--lj-border); }

/* ── Payment Options ─────────────────────────────────────────────────────── */
/* Target the payment gateway selection nested table */
.dataTable td > .dataTable1 { width: 100%; }
.dataTable .dataTable1 { border-collapse: collapse; }
.dataTable .dataTable1 tr { cursor: pointer; transition: background .15s; }
.dataTable .dataTable1 td {
  padding: 11px 10px;
  vertical-align: middle;
  border: none;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.dataTable .dataTable1 tr:last-child td { border-bottom: none; }

/* Highlight hovered payment row */
.dataTable .dataTable1 tr:hover td { background: #fffaf6; }

/* Highlight selected payment row via :has() */
.dataTable .dataTable1 tr:has(input[name="gateway"]:checked) td {
  background: #fff5ec;
}
/* Left accent bar on selected payment row */
.dataTable .dataTable1 tr:has(input[name="gateway"]:checked) td:first-child {
  border-left: 3px solid var(--lj-orange);
}

/* Payment images */
.dataTable .dataTable1 tr td img { vertical-align: middle; }

/* ── Reseller email input container ──────────────────────────────────────── */
.input-container {
  position: relative;
  width: 100%;
}
#enduser_email {
  width: 100%;
  padding: 7px 70px 7px 11px;
  box-sizing: border-box;
}
#editButton {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  background: #6c757d;
  font-weight: 600;
  color: #fff;
  border: none;
  cursor: pointer;
  padding: 4px 10px;
  border-radius: 4px;
  font-size: .78rem;
  z-index: 1;
  transition: background .2s;
}
#editButton:hover { background: var(--lj-dark); }

/* ── Redirect notice ─────────────────────────────────────────────────────── */
#redirectnotice {
  font-size: .82rem;
  color: var(--lj-muted);
  padding: 4px 0;
}

/* ── Discount row color ──────────────────────────────────────────────────── */
td[style*="color:green"] { color: var(--lj-green) !important; }
td[style*="color: green"] { color: var(--lj-green) !important; }

/* ── VAT notice paragraph ────────────────────────────────────────────────── */
p:has(a[href*="history.back"]) {
  background: #fff8e1;
  border: 1px solid #ffc107;
  border-radius: 6px;
  padding: 10px 14px;
  font-size: .88rem;
  margin: 12px 0;
}

/* ── Error table ─────────────────────────────────────────────────────────── */
.errTable {
  border: 1px solid #f5c6cb;
  background: #fff5f5;
  border-radius: var(--lj-radius);
  margin: 0 auto 20px;
  width: 100%;
}
.errTable td { padding: 10px 14px; color: #721c24; font-size: .9rem; }

/* ── VIES notice ─────────────────────────────────────────────────────────── */
.vies-notice {
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 6px;
  padding: 10px 14px;
  font-size: .88rem;
  margin-bottom: 16px;
}

/* ── Province select (IT) ────────────────────────────────────────────────── */
#province { display: none; }

/* ── Country / Client-type selects ──────────────────────────────────────── */
#country, #clientType { width: 100%; }
#itut { width: auto; min-width: 110px; }

/* ── Submit row notice text ──────────────────────────────────────────────── */
.dataTable1 tr:has(p) td p {
  font-size: .83rem;
  color: var(--lj-muted);
  margin: 0;
}

/* ── Helpers ─────────────────────────────────────────────────────────────── */
.d-none { display: none !important; }
.d-inlineBlock { display: inline-block; }
.prTitle { cursor: default; }
.SmallHint { font-size: .82em; color: var(--lj-muted); line-height: 1.4; }

/* ── Footer ──────────────────────────────────────────────────────────────── */
.lj-footer {
  background: var(--lj-dark);
  color: rgba(255,255,255,.65);
  padding: 28px 20px;
  text-align: center;
  font-size: .8rem;
  margin-top: 40px;
}
.lj-footer img {
  height: 28px;
  opacity: .7;
  filter: brightness(0) invert(1);
  margin-bottom: 10px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.lj-footer a { color: rgba(255,255,255,.75); }
.lj-footer a:hover { color: var(--lj-orange); text-decoration: none; }
.lj-footer-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.lj-footer-secure {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  font-size: .75rem;
  color: rgba(255,255,255,.5);
}
.lj-footer-secure i { color: var(--lj-orange); }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .lj-main { padding: 16px 8px 40px; }
  .cartTable th, .cartTable td { padding: 10px 8px; font-size: .82rem; }
  .dataTable tr td:first-child,
  .dataTable1 tr td:first-child {
    width: auto;
    white-space: normal;
    display: block;
  }
  .lj-step-label { font-size: .62rem; }
}
@media (max-width: 420px) {
  .lj-step-label { display: none; }
  .lj-navbar-brand img { height: 32px; }
}
