/*
Theme Name:   Divi Child – Jupoma CI
Theme URI:    https://jupoma.de
Description:  Child-Theme für Divi mit Jupoma Corporate Identity (Signal Amber, Industrial/Technical).
Author:       Jupoma
Author URI:   https://jupoma.de
Template:     Divi
Version:      1.0.0
Text Domain:  divi-child-jupoma
*/

@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter+Tight:wght@300;400;500;600;700&display=swap");

@font-face {
  font-family: "JetBrains Mono";
  src: url("fonts/JetBrainsMono-VariableFont_wght.ttf") format("truetype-variations"),
       url("fonts/JetBrainsMono-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("fonts/JetBrainsMono-Italic-VariableFont_wght.ttf") format("truetype-variations"),
       url("fonts/JetBrainsMono-Italic-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 800;
  font-style: italic;
  font-display: swap;
}

/* ═══════════════════════════════════════════════════════════════════════════
   §00 — TOKEN-SYSTEM (CSS Custom Properties)
   Quelle: Corporate Design/Jupoma Brand Guidelines.html §03
   Alle Farben, Fonts und Maße NUR über diese Variablen verwenden.
   ═══════════════════════════════════════════════════════════════════════════ */
:root {
  /* Grundpalette */
  --jp-paper:    #f4efe4;
  --jp-linen:    #ece6d8;
  --jp-sand:     #d8cfba;
  --jp-gravel:   #8c8070;
  --jp-soil:     #3a3228;
  --jp-ink:      #1a160f;

  /* Signal Amber (max. 5 % Flächenanteil!) */
  --jp-butter:   #fce8b8;
  --jp-honey:    #f3c463;
  --jp-amber:    #d97706;
  --jp-toast:    #b45e00;

  /* Status */
  --jp-moss:     #3a6349;  /* OK      */
  --jp-brick:    #9a2e1e;  /* Fehler  */

  /* Linien & Raster */
  --jp-rule:     rgba(26,22,15,.10);
  --jp-rule-md:  rgba(26,22,15,.18);
  --jp-rule-hv:  rgba(26,22,15,.30);
  --jp-grid:     32px;

  /* Typografie */
  --jp-display:  "Space Grotesk", "Inter Tight", -apple-system, sans-serif;
  --jp-sans:     "Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --jp-mono:     "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;
}

/* ═══════════════════════════════════════════════════════════════════════════
   §01 — GLOBAL BASE
   ═══════════════════════════════════════════════════════════════════════════ */
html,
body {
  background: var(--jp-paper);
  color: var(--jp-soil);
  font-family: var(--jp-sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Selection */
::selection {
  background: var(--jp-amber);
  color: var(--jp-ink);
}

/* ═══════════════════════════════════════════════════════════════════════════
   §02 — TYPOGRAFIE
   Überschreibt Divi-Defaults. Werte gemäß Brand Manual §04 Scale-Table.
   ═══════════════════════════════════════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6,
.et_pb_module h1, .et_pb_module h2, .et_pb_module h3,
.et_pb_module h4, .et_pb_module h5, .et_pb_module h6 {
  font-family: var(--jp-display);
  color: var(--jp-ink);
  font-weight: 700;
  letter-spacing: -.03em;
  line-height: 1.02;
}

h1, .et_pb_module h1 { font-size: clamp(40px, 6vw, 64px); letter-spacing: -.03em; }
h2, .et_pb_module h2 { font-size: clamp(32px, 4vw, 48px); letter-spacing: -.03em; }
h3, .et_pb_module h3 { font-size: 30px; font-weight: 600; letter-spacing: -.02em; }
h4, .et_pb_module h4 { font-size: 20px; font-weight: 500; letter-spacing: -.01em; }
h5, .et_pb_module h5 { font-size: 16px; font-weight: 500; }
h6, .et_pb_module h6 {
  font-family: var(--jp-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--jp-gravel);
}

p, li, .et_pb_text {
  font-family: var(--jp-sans);
  color: var(--jp-soil);
  font-size: 16px;
  line-height: 1.6;
}

/* Maximale Lesbarkeit: 60 Zeichen pro Zeile bei Body-Text */
.et_pb_text p { max-width: 60ch; }
.et_pb_text.jp-full-width p { max-width: none; }  /* Override-Klasse für volle Breite */

small, .jp-meta,
.et_pb_module .jp-meta {
  font-family: var(--jp-mono);
  font-size: 11px;
  letter-spacing: .06em;
  color: var(--jp-gravel);
}

/* Amber-Akzent im Text: <span class="jp-accent">upoma</span> */
.jp-accent { color: var(--jp-amber); }

/* ═══════════════════════════════════════════════════════════════════════════
   §03 — LINKS
   ═══════════════════════════════════════════════════════════════════════════ */
a {
  color: var(--jp-amber);
  text-decoration: none;
  transition: color .15s ease;
}
a:hover { color: var(--jp-toast); }

/* Links im Fließtext dezent unterstreichen */
.et_pb_text a {
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   §04 — BUTTONS (Divi-Buttons + WooCommerce-Buttons)
   Flach. Rechteckig. JetBrains Mono Uppercase. Kein Schatten.
   ═══════════════════════════════════════════════════════════════════════════ */
.et_pb_button,
.et_pb_button_module_wrapper .et_pb_button,
a.button, button, input[type="submit"], input[type="button"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce .button.add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce-page a.button,
.woocommerce-page button.button {
  font-family: var(--jp-mono) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;

  background: var(--jp-amber) !important;
  color: var(--jp-ink) !important;

  border: 1px solid var(--jp-amber) !important;
  border-radius: 0 !important;
  padding: 14px 24px !important;

  box-shadow: none !important;
  text-shadow: none !important;
  transition: background .15s ease, border-color .15s ease, color .15s ease !important;
}

.et_pb_button:hover,
a.button:hover, button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .button.add_to_cart_button:hover {
  background: var(--jp-toast) !important;
  border-color: var(--jp-toast) !important;
  color: var(--jp-paper) !important;
  padding: 14px 24px !important;  /* verhindert Divi-Padding-Shift beim Hover */
}

/* Divi fügt gern Pfeil-Icons an Buttons — deaktivieren */
.et_pb_button:after,
.et_pb_button:before { display: none !important; }

/* Sekundär-Button: Outline auf Paper */
.et_pb_button.jp-btn-ghost,
a.button.jp-btn-ghost {
  background: transparent !important;
  color: var(--jp-ink) !important;
  border: 1px solid var(--jp-ink) !important;
}
.et_pb_button.jp-btn-ghost:hover,
a.button.jp-btn-ghost:hover {
  background: var(--jp-ink) !important;
  color: var(--jp-paper) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   §05 — FORMULARE
   ═══════════════════════════════════════════════════════════════════════════ */
input[type="text"], input[type="email"], input[type="tel"],
input[type="number"], input[type="password"], input[type="search"],
input[type="url"], textarea, select,
.et_pb_contact_field input, .et_pb_contact_field textarea,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  font-family: var(--jp-sans);
  font-size: 15px;
  color: var(--jp-ink);
  background: var(--jp-linen);
  border: 1px solid var(--jp-rule-md);
  border-radius: 0;
  padding: 12px 14px;
  transition: border-color .15s ease, background .15s ease;
}

input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--jp-amber) !important;
  background: var(--jp-paper);
}

label {
  font-family: var(--jp-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--jp-gravel);
}

/* ═══════════════════════════════════════════════════════════════════════════
   §06 — NAVIGATION / HEADER
   Voraussetzung: Theme-Builder-Header mit den Klassen unten.
   ═══════════════════════════════════════════════════════════════════════════ */
#main-header,
.et_pb_menu,
.jp-nav {
  background: color-mix(in oklab, var(--jp-paper) 88%, transparent) !important;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--jp-rule-md);
  box-shadow: none !important;
}

#top-menu li a,
.et_pb_menu .et-menu li a,
.jp-nav a {
  font-family: var(--jp-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--jp-gravel);
  padding: 0 16px;
  line-height: 52px;
  border-right: 1px solid var(--jp-rule);
  transition: color .15s, background .15s;
}

#top-menu li a:hover,
.et_pb_menu .et-menu li a:hover {
  color: var(--jp-ink);
  background: rgba(26,22,15,.04);
  opacity: 1;
}

#top-menu li.current-menu-item > a {
  color: var(--jp-ink) !important;
}

/* Wortmarken-Logo (falls als Text statt SVG) */
.jp-wordmark {
  font-family: var(--jp-display);
  font-weight: 700;
  letter-spacing: -.045em;
  font-size: 28px;
  color: var(--jp-ink);
  line-height: 1;
}
.jp-wordmark .jp-accent { color: var(--jp-amber); }

/* ═══════════════════════════════════════════════════════════════════════════
   §07 — WOOCOMMERCE
   Produktlisting, Produktdetail, Warenkorb, Checkout.
   ═══════════════════════════════════════════════════════════════════════════ */

/* Produkt-Grid: feste Linien statt Divi-Schatten */
.woocommerce ul.products {
  border: 1px solid var(--jp-rule-md);
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
@media (max-width: 900px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .woocommerce ul.products { grid-template-columns: 1fr; } }

.woocommerce ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  padding: 24px !important;
  border-right: 1px solid var(--jp-rule-md);
  border-bottom: 1px solid var(--jp-rule-md);
  background: var(--jp-paper);
  transition: background .2s;
}
.woocommerce ul.products li.product:hover {
  background: var(--jp-linen);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--jp-display) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  letter-spacing: -.01em;
  color: var(--jp-ink);
  padding: 16px 0 6px !important;
}

.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--jp-mono) !important;
  font-size: 14px !important;
  font-weight: 500;
  letter-spacing: .04em;
  color: var(--jp-amber) !important;
}

/* SKU, Stock, Kategorie: Mono-Meta */
.woocommerce div.product .product_meta,
.woocommerce .sku_wrapper,
.woocommerce .stock {
  font-family: var(--jp-mono) !important;
  font-size: 11px !important;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--jp-gravel);
}
.woocommerce .stock.in-stock { color: var(--jp-moss); }
.woocommerce .stock.out-of-stock { color: var(--jp-brick); }

/* Produktdetail-Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-bottom: 1px solid var(--jp-rule-md);
  padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  border-right: 1px solid var(--jp-rule) !important;
  border-radius: 0 !important;
  margin: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--jp-mono) !important;
  font-size: 11px !important;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--jp-gravel) !important;
  padding: 14px 20px !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--jp-ink) !important;
  background: var(--jp-linen) !important;
}

/* Sale-Badge: Amber statt Divi-Grün */
.woocommerce span.onsale {
  background: var(--jp-amber) !important;
  color: var(--jp-ink) !important;
  font-family: var(--jp-mono) !important;
  font-size: 10px !important;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: 0 !important;
  padding: 4px 10px !important;
  min-height: 0 !important;
  min-width: 0 !important;
  line-height: 1.4 !important;
}

/* Warenkorb-Tabelle */
.woocommerce table.shop_table {
  border: 1px solid var(--jp-rule-md);
  border-radius: 0 !important;
  border-collapse: collapse !important;
}
.woocommerce table.shop_table th {
  font-family: var(--jp-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--jp-ink);
  background: var(--jp-linen);
  border-bottom: 1px solid var(--jp-rule-md);
  padding: 12px 16px;
}
.woocommerce table.shop_table td {
  border-top: 1px solid var(--jp-rule);
  padding: 16px;
}

/* Benachrichtigungen */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: 0 !important;
  border-top: none !important;
  border-left: 3px solid var(--jp-amber) !important;
  background: var(--jp-linen) !important;
  color: var(--jp-soil) !important;
  font-family: var(--jp-sans);
  padding: 14px 18px !important;
}
.woocommerce-message { border-left-color: var(--jp-moss) !important; }
.woocommerce-error   { border-left-color: var(--jp-brick) !important; }
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before { display: none !important; }

/* ═══════════════════════════════════════════════════════════════════════════
   §08 — DIVI-SPEZIFISCHE OVERRIDES
   ═══════════════════════════════════════════════════════════════════════════ */

/* Divi-Sections: saubere Trennlinien statt Schatten */
.et_pb_section {
  border-bottom: 1px solid var(--jp-rule-md);
  box-shadow: none !important;
}
.et_pb_section.jp-no-rule { border-bottom: none; }

/* Blurbs: Icon in Amber */
.et_pb_blurb .et_pb_main_blurb_image .et-pb-icon {
  color: var(--jp-amber) !important;
}

/* Divider: Sand-Linie */
.et_pb_divider:before {
  border-top-color: var(--jp-sand) !important;
  border-top-width: 1px !important;
}

/* Pricing-Tables, Counter, Accordion-Header etc. */
.et_pb_pricing_table_button,
.et_pb_tabs_controls li.et_pb_tab_active,
.et_pb_toggle_title {
  font-family: var(--jp-mono) !important;
  letter-spacing: .1em;
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════════════════════
   §09 — UTILITY-KLASSEN
   Für einzelne Divi-Text-Module oder HTML-Blöcke verwendbar.
   ═══════════════════════════════════════════════════════════════════════════ */
.jp-tag {
  display: inline-block;
  font-family: var(--jp-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  border: 1px solid var(--jp-rule-hv);
  padding: 4px 8px;
  color: var(--jp-gravel);
}
.jp-tag.jp-tag-amber {
  border-color: var(--jp-amber);
  color: var(--jp-toast);
  background: var(--jp-butter);
}

.jp-sec-label {
  font-family: var(--jp-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--jp-toast);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.jp-sec-label::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 1px;
  background: var(--jp-amber);
}

.jp-grid-bg {
  background-image:
    linear-gradient(var(--jp-rule) 1px, transparent 1px),
    linear-gradient(90deg, var(--jp-rule) 1px, transparent 1px);
  background-size: var(--jp-grid) var(--jp-grid);
}

/* ═══════════════════════════════════════════════════════════════════════════
   §10 — RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 860px) {
  h1, .et_pb_module h1 { font-size: 36px; }
  h2, .et_pb_module h2 { font-size: 28px; }

  .et_pb_button,
  .woocommerce a.button,
  .woocommerce button.button {
    width: 100%;
    text-align: center;
  }
}

/* ==========================================================================
   JP11 - Template utilities for Divi Theme Builder
   These classes are used by the migration docs for global header/footer,
   product pages, category pages, cart and checkout.
   ========================================================================== */
.jp-shell {
  max-width: 1360px;
  margin: 0 auto;
  padding-left: 48px;
  padding-right: 48px;
}

.jp-section-tight { padding-top: 48px; padding-bottom: 48px; }
.jp-section { padding-top: 80px; padding-bottom: 80px; }
.jp-section-linen { background: var(--jp-linen); }
.jp-section-ink { background: var(--jp-ink); color: var(--jp-paper); }
.jp-section-ink h1,
.jp-section-ink h2,
.jp-section-ink h3,
.jp-section-ink p { color: var(--jp-paper); }

.jp-grid-surface {
  background-color: var(--jp-linen);
  background-image:
    linear-gradient(var(--jp-rule) 1px, transparent 1px),
    linear-gradient(90deg, var(--jp-rule) 1px, transparent 1px);
  background-size: var(--jp-grid) var(--jp-grid);
}

.jp-two-col {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
  gap: 48px;
  align-items: start;
}

.jp-rule-box {
  border: 1px solid var(--jp-rule-md);
  background: var(--jp-paper);
}

.jp-rule-box > * + * { border-top: 1px solid var(--jp-rule); }

.jp-mono-row {
  display: grid;
  grid-template-columns: minmax(140px, .38fr) 1fr;
  gap: 16px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--jp-rule);
  font-family: var(--jp-mono);
  font-size: 12px;
  letter-spacing: .04em;
}
.jp-mono-row:last-child { border-bottom: 0; }
.jp-mono-row span:first-child {
  color: var(--jp-gravel);
  text-transform: uppercase;
  letter-spacing: .1em;
}

.jp-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--jp-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--jp-gravel);
}
.jp-status::before {
  content: "";
  width: 7px;
  height: 7px;
  background: var(--jp-amber);
  display: inline-block;
}
.jp-status-ok::before { background: var(--jp-moss); }
.jp-status-warn::before { background: var(--jp-brick); }

/* Header and footer built in Divi Theme Builder */
.jp-global-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(244,239,228,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--jp-rule-md);
}

.jp-header-inner {
  min-height: 64px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
}

.jp-header-nav {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  border-left: 1px solid var(--jp-rule);
}

.jp-header-nav a,
.jp-header-actions a {
  font-family: var(--jp-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--jp-gravel);
  padding: 21px 16px;
  border-right: 1px solid var(--jp-rule);
}

.jp-header-nav a:hover,
.jp-header-actions a:hover {
  color: var(--jp-ink);
  background: rgba(26,22,15,.04);
}

.jp-global-footer {
  border-top: 2px solid var(--jp-ink);
  background: var(--jp-linen);
}

.jp-footer-grid {
  display: grid;
  grid-template-columns: minmax(220px, .8fr) repeat(3, minmax(160px, 1fr));
  gap: 32px;
  padding: 48px 0;
}

.jp-footer-grid h3 {
  font-family: var(--jp-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 16px;
}

.jp-footer-grid a,
.jp-footer-grid p,
.jp-footer-grid li {
  font-size: 14px;
  color: var(--jp-soil);
}

/* Product detail template */
.single-product .product { color: var(--jp-soil); }

.jp-product-hero,
.woocommerce div.product div.summary,
.woocommerce div.product div.images {
  background: transparent;
}

.woocommerce div.product div.images .woocommerce-product-gallery__wrapper {
  margin: 0;
  border: 1px solid var(--jp-rule-md);
  background-color: var(--jp-linen);
  background-image:
    linear-gradient(var(--jp-rule) 1px, transparent 1px),
    linear-gradient(90deg, var(--jp-rule) 1px, transparent 1px);
  background-size: var(--jp-grid) var(--jp-grid);
}

.woocommerce div.product div.images img {
  display: block;
  border-radius: 0 !important;
}

.woocommerce div.product .product_title {
  font-family: var(--jp-display);
  font-size: clamp(36px, 5vw, 56px);
  line-height: .98;
  letter-spacing: -.035em;
  margin-bottom: 16px;
}

.woocommerce div.product form.cart {
  border: 1px solid var(--jp-rule-md);
  background: var(--jp-linen);
  padding: 20px;
  margin: 24px 0;
}

.woocommerce div.product form.cart table.variations {
  border-collapse: collapse;
  margin-bottom: 16px;
}

.woocommerce div.product form.cart table.variations tr { border-bottom: 1px solid var(--jp-rule); }

.woocommerce div.product form.cart table.variations th,
.woocommerce div.product form.cart table.variations td {
  padding: 12px 0;
  vertical-align: middle;
}

.woocommerce div.product form.cart table.variations label { color: var(--jp-ink); }

.woocommerce .quantity .qty {
  width: 76px;
  min-height: 46px;
  font-family: var(--jp-mono);
  text-align: center;
  background: var(--jp-paper);
  border: 1px solid var(--jp-rule-md);
  border-radius: 0;
}

.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: 17px;
  line-height: 1.58;
  max-width: 58ch;
}

.woocommerce div.product .woocommerce-product-details__short-description p { max-width: 58ch; }

.jp-legal-note,
.woocommerce-Tabs-panel--product_safety,
.woocommerce-Tabs-panel--productsafety {
  border-left: 3px solid var(--jp-brick);
  background: var(--jp-linen);
  padding: 16px 20px;
  margin: 24px 0;
}

/* Shop and category archive template */
.woocommerce .woocommerce-ordering select,
.woocommerce .woocommerce-result-count {
  font-family: var(--jp-mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--jp-gravel);
}

.woocommerce ul.products li.product a img {
  aspect-ratio: 4 / 3;
  object-fit: contain;
  background-color: var(--jp-linen);
  background-image:
    linear-gradient(var(--jp-rule) 1px, transparent 1px),
    linear-gradient(90deg, var(--jp-rule) 1px, transparent 1px);
  background-size: var(--jp-grid) var(--jp-grid);
  border: 1px solid var(--jp-rule);
  margin: 0 0 16px !important;
}

.woocommerce ul.products li.product .button {
  width: 100%;
  text-align: center;
  margin-top: 16px !important;
}

.woocommerce-loop-category__title,
.woocommerce-products-header__title { font-family: var(--jp-display) !important; }

/* JTL HTML normalization */
.woocommerce-product-details__short-description,
.woocommerce-Tabs-panel--description,
#tab-description {
  font-family: var(--jp-sans) !important;
  color: var(--jp-soil) !important;
  line-height: 1.6;
}

.woocommerce-Tabs-panel--description *,
#tab-description * {
  font-family: inherit !important;
  color: inherit !important;
  background: transparent !important;
  box-shadow: none !important;
  text-shadow: none !important;
}

.woocommerce-Tabs-panel--description h1,
.woocommerce-Tabs-panel--description h2,
.woocommerce-Tabs-panel--description h3,
#tab-description h1,
#tab-description h2,
#tab-description h3 {
  font-family: var(--jp-display) !important;
  color: var(--jp-ink) !important;
  font-weight: 700;
  letter-spacing: -.02em;
  margin: 32px 0 12px;
}

.woocommerce-Tabs-panel--description p,
#tab-description p { max-width: 68ch; }

.woocommerce-Tabs-panel--description ul,
.woocommerce-Tabs-panel--description ol,
#tab-description ul,
#tab-description ol {
  margin: 16px 0 24px;
  padding-left: 20px;
}

.woocommerce-Tabs-panel--description table,
#tab-description table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--jp-rule-md);
  font-family: var(--jp-mono) !important;
  font-size: 12px !important;
  margin: 24px 0;
}

.woocommerce-Tabs-panel--description table td,
.woocommerce-Tabs-panel--description table th,
#tab-description table td,
#tab-description table th {
  border: 1px solid var(--jp-rule);
  padding: 8px 12px;
  text-align: left;
}

.woocommerce-Tabs-panel--description table th,
#tab-description table th {
  background: var(--jp-linen) !important;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.woocommerce-Tabs-panel--description img,
#tab-description img {
  max-width: 100%;
  height: auto;
  border: 1px solid var(--jp-rule-md);
  border-radius: 0 !important;
}

/* Approved JTL content classes */
.jp-lead {
  font-family: var(--jp-display) !important;
  font-size: 20px !important;
  font-weight: 500;
  color: var(--jp-ink) !important;
  letter-spacing: -.01em;
  line-height: 1.35;
  margin: 0 0 24px;
  max-width: 58ch;
}

table.jp-specs {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--jp-rule-md);
  font-family: var(--jp-mono) !important;
  font-size: 12px !important;
}
table.jp-specs td {
  border: 1px solid var(--jp-rule);
  padding: 10px 14px;
}
table.jp-specs td:first-child {
  background: var(--jp-linen) !important;
  color: var(--jp-gravel) !important;
  text-transform: uppercase;
  letter-spacing: .08em;
  width: 40%;
}

.jp-callout {
  border-left: 3px solid var(--jp-amber);
  background: var(--jp-butter) !important;
  padding: 16px 20px;
  margin: 24px 0;
  color: var(--jp-soil) !important;
}
.jp-callout.jp-callout-warn {
  border-left-color: var(--jp-brick);
  background: color-mix(in srgb, var(--jp-brick) 12%, var(--jp-paper)) !important;
}
.jp-callout.jp-callout-ok {
  border-left-color: var(--jp-moss);
  background: color-mix(in srgb, var(--jp-moss) 12%, var(--jp-paper)) !important;
}

ul.jp-features {
  list-style: none;
  margin: 24px 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border: 1px solid var(--jp-rule-md);
}
ul.jp-features li {
  padding: 16px;
  border-right: 1px solid var(--jp-rule);
  border-bottom: 1px solid var(--jp-rule);
  font-size: 14px;
  line-height: 1.5;
}

ol.jp-steps {
  counter-reset: jp-step;
  list-style: none;
  padding: 0;
  margin: 24px 0;
}
ol.jp-steps li {
  counter-increment: jp-step;
  padding: 12px 0 12px 52px;
  position: relative;
  border-top: 1px solid var(--jp-rule);
  font-size: 15px;
}
ol.jp-steps li::before {
  content: counter(jp-step, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 14px;
  font-family: var(--jp-mono);
  font-size: 11px;
  color: var(--jp-amber);
  letter-spacing: .1em;
}

.jp-cta {
  border: 1px solid var(--jp-ink);
  background: var(--jp-ink) !important;
  color: var(--jp-paper) !important;
  padding: 24px;
  margin: 32px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.jp-cta h3,
.jp-cta p { color: var(--jp-paper) !important; margin: 0; }
.jp-cta .jp-accent { color: var(--jp-amber) !important; }

/* Cart and checkout: visual alignment only */
.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review,
.woocommerce-checkout .woocommerce-checkout-review-order,
.woocommerce .woocommerce-form-coupon,
.woocommerce .woocommerce-form-login {
  border: 1px solid var(--jp-rule-md);
  background: var(--jp-paper);
  border-radius: 0;
  padding: 24px;
  box-shadow: none;
}

.woocommerce-checkout h3,
.woocommerce-cart .cart_totals h2 { font-size: 24px; }

.woocommerce-checkout-review-order-table { border-collapse: collapse !important; }

.woocommerce-checkout-payment {
  background: var(--jp-linen) !important;
  border-radius: 0 !important;
}

.woocommerce-checkout-payment ul.payment_methods {
  border-bottom: 1px solid var(--jp-rule-md) !important;
}

@media (max-width: 980px) {
  .jp-shell {
    padding-left: 20px;
    padding-right: 20px;
  }
  .jp-two-col {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .jp-header-inner {
    grid-template-columns: 1fr;
    gap: 0;
    padding-top: 14px;
    padding-bottom: 14px;
  }
  .jp-header-nav,
  .jp-header-actions {
    justify-content: flex-start;
    width: 100%;
    overflow-x: auto;
  }
  .jp-footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 600px) {
  .jp-section { padding-top: 56px; padding-bottom: 56px; }
  .jp-footer-grid,
  ul.jp-features { grid-template-columns: 1fr; }
  .jp-cta { display: block; }
  .jp-cta .button,
  .jp-cta .et_pb_button { margin-top: 18px; }
}
