/**
 * Litigation Desk — public storefront editorial styling (v1.6.0)
 *
 * Two responsibilities:
 *   1. Override WooCommerce's standard product/cart/checkout selectors
 *      with the Litigation Docs editorial vocabulary
 *   2. Style the [litdesk_product_card] and [litdesk_pricing_table]
 *      shortcodes
 *
 * Design tokens — match the WP-admin tokens exactly so a customer
 * who sees the storefront, then installs and activates, then opens
 * the desktop app, encounters one consistent visual language.
 */

:root {
  --litdesk-storefront-rust:       #884231;
  --litdesk-storefront-rust-deep:  #6F3527;
  --litdesk-storefront-paper:      #FAF7F2;
  --litdesk-storefront-paper-deep: #F2EEE8;
  --litdesk-storefront-ink:        #1D1B19;
  --litdesk-storefront-ink-2:      #3A3733;
  --litdesk-storefront-ink-3:      #6B6864;
  --litdesk-storefront-line:       #DFD9CE;
  --litdesk-storefront-line-soft:  rgba(223, 217, 206, 0.5);

  --litdesk-storefront-display:    "Fraunces", Georgia, "Times New Roman", serif;
  --litdesk-storefront-body:       "Switzer", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --litdesk-storefront-mono:       "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;
}

/* =============================================================================
   WooCommerce standard selector overrides
   ============================================================================= */

/* ---- Single product page (.product .summary) ---- */

.woocommerce div.product .summary,
.woocommerce-page div.product .summary {
  padding: 24px 0;
}

.woocommerce div.product .product_title,
.woocommerce-page div.product .product_title {
  font-family: var(--litdesk-storefront-display);
  font-size: 36px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.1;
  color: var(--litdesk-storefront-ink);
  margin: 0 0 12px;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price,
.woocommerce-page div.product p.price,
.woocommerce-page div.product span.price {
  font-family: var(--litdesk-storefront-mono);
  font-size: 28px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  color: var(--litdesk-storefront-ink);
  margin: 0 0 18px;
}

.woocommerce div.product .woocommerce-product-details__short-description,
.woocommerce-page div.product .woocommerce-product-details__short-description {
  font-family: var(--litdesk-storefront-display);
  font-size: 17px;
  font-style: italic;
  color: var(--litdesk-storefront-ink-2);
  line-height: 1.55;
  max-width: 60ch;
  margin: 0 0 24px;
}

/* "Add to cart" button — rust primary */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-page a.button,
.woocommerce-page button.button,
.woocommerce-page input.button,
.woocommerce-page #respond input#submit {
  background: var(--litdesk-storefront-rust);
  color: white;
  border: 1px solid var(--litdesk-storefront-rust);
  border-radius: 3px;
  padding: 12px 22px;
  font-family: var(--litdesk-storefront-body);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.01em;
  text-transform: none;
  text-shadow: none;
  box-shadow: none;
  transition: background 150ms, border-color 150ms;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--litdesk-storefront-rust-deep);
  border-color: var(--litdesk-storefront-rust-deep);
}

/* ---- Cart page ---- */

.woocommerce-cart .cart_totals h2,
.woocommerce-checkout #order_review_heading,
.woocommerce h2 {
  font-family: var(--litdesk-storefront-display);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--litdesk-storefront-ink);
}

.woocommerce table.shop_table,
.woocommerce-page table.shop_table {
  background: white;
  border: 1px solid var(--litdesk-storefront-line);
  border-radius: 4px;
  overflow: hidden;
}

.woocommerce table.shop_table thead th,
.woocommerce-page table.shop_table thead th {
  background: var(--litdesk-storefront-paper);
  border-bottom: 1px solid var(--litdesk-storefront-line);
  font-family: var(--litdesk-storefront-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--litdesk-storefront-ink-3);
  padding: 12px 16px;
}

.woocommerce table.shop_table td,
.woocommerce-page table.shop_table td {
  padding: 14px 16px;
  font-family: var(--litdesk-storefront-body);
  border-color: var(--litdesk-storefront-line);
}

.woocommerce table.shop_table .product-name,
.woocommerce-page table.shop_table .product-name {
  font-family: var(--litdesk-storefront-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--litdesk-storefront-ink);
}

.woocommerce .quantity .qty {
  font-family: var(--litdesk-storefront-mono);
  font-variant-numeric: tabular-nums;
  border: 1px solid var(--litdesk-storefront-line);
  border-radius: 3px;
  padding: 6px 10px;
}

/* Coupon entry */
.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
  background: var(--litdesk-storefront-paper);
  border: 1px solid var(--litdesk-storefront-line);
  border-left: 3px solid var(--litdesk-storefront-rust);
  border-radius: 0 3px 3px 0;
}

/* ---- Checkout page ---- */

.woocommerce form .form-row label,
.woocommerce-page form .form-row label {
  font-family: var(--litdesk-storefront-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--litdesk-storefront-ink-3);
  margin-bottom: 4px;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row textarea,
.woocommerce-page form .form-row select {
  font-family: var(--litdesk-storefront-body);
  font-size: 14px;
  padding: 10px 12px;
  border: 1px solid var(--litdesk-storefront-line);
  border-radius: 3px;
  background: white;
  transition: border-color 150ms;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--litdesk-storefront-rust);
  outline: none;
}

/* Order review totals */
.woocommerce-checkout .order_total {
  font-family: var(--litdesk-storefront-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}

/* Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  background: white;
  border: 1px solid var(--litdesk-storefront-line);
  border-left: 3px solid var(--litdesk-storefront-rust);
  border-radius: 0 3px 3px 0;
  padding: 14px 18px;
  font-family: var(--litdesk-storefront-display);
  font-size: 14px;
  color: var(--litdesk-storefront-ink-2);
}

/* =============================================================================
   [litdesk_product_card] shortcode
   ============================================================================= */

.litdesk-storefront__card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 28px 30px;
  background: white;
  border: 1px solid var(--litdesk-storefront-line);
  border-left: 3px solid var(--litdesk-storefront-rust);
  border-radius: 0 4px 4px 0;
  max-width: 520px;
  margin: 24px 0;
}

.litdesk-storefront__card-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.litdesk-storefront__card-eyebrow {
  font-family: var(--litdesk-storefront-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--litdesk-storefront-rust-deep);
}

.litdesk-storefront__card-title {
  margin: 0;
  font-family: var(--litdesk-storefront-display);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.15;
  color: var(--litdesk-storefront-ink);
}

.litdesk-storefront__card-lede {
  font-family: var(--litdesk-storefront-display);
  font-size: 15px;
  font-style: italic;
  color: var(--litdesk-storefront-ink-2);
  line-height: 1.55;
}

.litdesk-storefront__card-lede p {
  margin: 0 0 8px;
}
.litdesk-storefront__card-lede p:last-child { margin-bottom: 0; }

.litdesk-storefront__card-price-row {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding-top: 4px;
  border-top: 1px solid var(--litdesk-storefront-line-soft);
  padding-top: 14px;
}

.litdesk-storefront__card-price {
  font-family: var(--litdesk-storefront-mono);
  font-size: 26px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--litdesk-storefront-ink);
  letter-spacing: -0.01em;
}

.litdesk-storefront__card-price .amount {
  color: inherit;
  font-weight: inherit;
  font-family: inherit;
}

.litdesk-storefront__card-seats {
  font-family: var(--litdesk-storefront-display);
  font-size: 13px;
  font-style: italic;
  color: var(--litdesk-storefront-ink-3);
}
.litdesk-storefront__card-seats em {
  font-style: italic;
  font-weight: 600;
  color: var(--litdesk-storefront-ink-2);
}

.litdesk-storefront__card-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  padding: 12px 20px;
  background: var(--litdesk-storefront-rust);
  color: white;
  text-decoration: none;
  border-radius: 3px;
  font-family: var(--litdesk-storefront-body);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: background 150ms;
}
.litdesk-storefront__card-cta:hover {
  background: var(--litdesk-storefront-rust-deep);
  color: white;
}

.litdesk-storefront__card-cta-arrow {
  font-family: var(--litdesk-storefront-mono);
  font-weight: 500;
}

/* =============================================================================
   [litdesk_pricing_table] shortcode
   ============================================================================= */

.litdesk-storefront__pricing {
  margin: 32px 0;
}

.litdesk-storefront__pricing-header {
  text-align: center;
  margin-bottom: 32px;
  padding: 0 16px;
}

.litdesk-storefront__pricing-eyebrow {
  display: block;
  font-family: var(--litdesk-storefront-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--litdesk-storefront-rust-deep);
  margin-bottom: 10px;
}

.litdesk-storefront__pricing-heading {
  margin: 0 0 14px;
  font-family: var(--litdesk-storefront-display);
  font-size: 38px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.05;
  color: var(--litdesk-storefront-ink);
}

.litdesk-storefront__pricing-lede {
  margin: 0 auto;
  max-width: 56ch;
  font-family: var(--litdesk-storefront-display);
  font-size: 17px;
  font-style: italic;
  color: var(--litdesk-storefront-ink-2);
  line-height: 1.55;
}

.litdesk-storefront__pricing-lede em {
  font-weight: 600;
  font-style: italic;
  color: var(--litdesk-storefront-ink);
}

.litdesk-storefront__pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  align-items: stretch;
  margin: 0 0 32px;
}

.litdesk-storefront__pricing-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 28px 24px;
  background: white;
  border: 1px solid var(--litdesk-storefront-line);
  border-radius: 4px;
  transition: border-color 200ms, transform 200ms;
}
.litdesk-storefront__pricing-card:hover {
  border-color: var(--litdesk-storefront-rust);
  transform: translateY(-2px);
}

.litdesk-storefront__pricing-card-header {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--litdesk-storefront-line);
}

.litdesk-storefront__pricing-card-eyebrow {
  font-family: var(--litdesk-storefront-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--litdesk-storefront-rust-deep);
}

.litdesk-storefront__pricing-card-title {
  margin: 0;
  font-family: var(--litdesk-storefront-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.15;
  color: var(--litdesk-storefront-ink);
}

.litdesk-storefront__pricing-card-price {
  font-family: var(--litdesk-storefront-mono);
  font-size: 32px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  color: var(--litdesk-storefront-ink);
  line-height: 1;
}

.litdesk-storefront__pricing-card-price .amount {
  color: inherit;
  font-weight: inherit;
  font-family: inherit;
}

.litdesk-storefront__pricing-card-features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

.litdesk-storefront__pricing-card-features li {
  font-family: var(--litdesk-storefront-display);
  font-size: 14px;
  color: var(--litdesk-storefront-ink-2);
  line-height: 1.5;
  padding-left: 18px;
  position: relative;
}

.litdesk-storefront__pricing-card-features li::before {
  content: "§";
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--litdesk-storefront-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--litdesk-storefront-rust);
}

.litdesk-storefront__pricing-card-features strong {
  font-weight: 600;
  color: var(--litdesk-storefront-ink);
}

.litdesk-storefront__pricing-card-features em {
  font-style: italic;
  color: var(--litdesk-storefront-ink-2);
}

.litdesk-storefront__pricing-card-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 18px;
  background: var(--litdesk-storefront-rust);
  color: white;
  text-decoration: none;
  border-radius: 3px;
  font-family: var(--litdesk-storefront-body);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: background 150ms;
  margin-top: auto;
}
.litdesk-storefront__pricing-card-cta:hover {
  background: var(--litdesk-storefront-rust-deep);
  color: white;
}

.litdesk-storefront__pricing-card-cta-arrow {
  font-family: var(--litdesk-storefront-mono);
  font-weight: 500;
}

.litdesk-storefront__pricing-foot {
  text-align: center;
  margin: 0;
  font-family: var(--litdesk-storefront-display);
  font-size: 14px;
  color: var(--litdesk-storefront-ink-3);
  line-height: 1.6;
}
.litdesk-storefront__pricing-foot em {
  font-style: italic;
  font-weight: 600;
  color: var(--litdesk-storefront-ink-2);
}
.litdesk-storefront__pricing-foot a {
  color: var(--litdesk-storefront-rust-deep);
  text-decoration: underline;
  text-decoration-color: var(--litdesk-storefront-rust);
  text-underline-offset: 2px;
}
.litdesk-storefront__pricing-foot a:hover {
  color: var(--litdesk-storefront-rust);
}
