/*
Theme Name: KMX-Wear
Theme URI: https://kmx-wear.de
Author: KMX-Wear
Author URI: https://kmx-wear.de
Description: Eigenes WordPress-Theme für KMX-Wear. Klassisches Druckerei-Design in Weiß und Orange, mit voller WooCommerce-Unterstützung. Funktioniert mit den KMX-Plugins (Startseite, Kontakt) zusammen.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kmx-wear
Tags: ecommerce, woocommerce, custom-colors, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   ROOT VARIABLES
   ============================================================ */
:root {
  --kmx-orange:      #FF5E1A;
  --kmx-orange-deep: #E04A0A;
  --kmx-orange-soft: #FFE8DC;
  --kmx-white:       #FFFFFF;
  --kmx-off-white:   #FAF8F5;
  --kmx-ink:         #0E0E0E;
  --kmx-grey:        #6B6B6B;
  --kmx-line:        rgba(14, 14, 14, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Bricolage Grotesque', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--kmx-off-white);
  color: var(--kmx-ink);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
::selection { background: var(--kmx-orange); color: var(--kmx-white); }

a { color: inherit; text-decoration: none; }
a:hover { color: var(--kmx-orange); }
img { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; cursor: pointer; }

/* Skip link für Barrierefreiheit */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 9999;
}
.skip-link:focus {
  left: 16px;
  top: 16px;
  background: var(--kmx-ink);
  color: var(--kmx-white);
  padding: 12px 20px;
  border-radius: 8px;
}

/* ============================================================
   HEADER / NAVIGATION
   ============================================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  padding: 22px 48px;
  background: rgba(250, 248, 245, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 1000;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--kmx-line);
}

.site-logo {
  font-family: 'Archivo Black', sans-serif;
  font-size: 22px;
  letter-spacing: -0.02em;
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--kmx-ink);
}
.site-logo:hover { color: var(--kmx-ink); }
.site-logo .mark { color: var(--kmx-orange); font-size: 28px; }
.site-logo img { max-height: 48px; width: auto; }

.main-nav ul {
  display: flex;
  gap: 36px;
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.main-nav a {
  position: relative;
  padding: 4px 0;
  transition: color 0.2s;
}
.main-nav a::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0; height: 2px;
  background: var(--kmx-orange);
  transition: width 0.3s ease;
}
.main-nav a:hover::after,
.main-nav .current-menu-item > a::after,
.main-nav .current_page_item > a::after { width: 100%; }
.main-nav .current-menu-item > a,
.main-nav .current_page_item > a { color: var(--kmx-orange); }

.header-actions { display: flex; align-items: center; gap: 12px; }

.header-cart {
  background: var(--kmx-ink);
  color: var(--kmx-white);
  border: none;
  padding: 10px 20px;
  border-radius: 999px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
}
.header-cart:hover { background: var(--kmx-orange); color: var(--kmx-white); transform: translateY(-1px); }
.cart-count {
  background: var(--kmx-orange);
  color: var(--kmx-white);
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 10px;
  min-width: 18px;
  text-align: center;
}
.header-cart:hover .cart-count { background: var(--kmx-white); color: var(--kmx-orange); }

.menu-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--kmx-ink);
  width: 40px; height: 40px;
  border-radius: 50%;
  font-size: 18px;
  align-items: center;
  justify-content: center;
}

/* ============================================================
   MAIN CONTENT (Abstand für fixierten Header)
   ============================================================ */
#main {
  padding-top: 88px; /* nur falls keine page-header da ist */
}
#main.has-hero { padding-top: 0; }

/* ============================================================
   PAGE HEADERS
   ============================================================ */
.page-header {
  padding: 140px 48px 60px;
  background: var(--kmx-white);
  border-bottom: 1px solid var(--kmx-line);
}
.page-header .page-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--kmx-orange);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.page-header .page-eyebrow::before {
  content: '';
  width: 32px; height: 1px;
  background: var(--kmx-orange);
}
.page-header h1 {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(48px, 7vw, 96px);
  letter-spacing: -0.04em;
  line-height: 0.95;
  margin: 0 0 12px;
}
.page-header h1 em { color: var(--kmx-orange); font-style: italic; }
.page-header p { color: var(--kmx-grey); font-size: 18px; max-width: 540px; }

/* ============================================================
   ENTRY CONTENT
   ============================================================ */
.entry-content {
  max-width: 720px;
  margin: 0 auto;
  padding: 60px 24px;
  font-size: 17px;
  line-height: 1.7;
}
.entry-content > * { margin-bottom: 1em; }
.entry-content h1, .entry-content h2, .entry-content h3,
.entry-content h4, .entry-content h5, .entry-content h6 {
  font-family: 'Archivo Black', sans-serif;
  letter-spacing: -0.02em;
  margin-top: 2em;
  line-height: 1.2;
}
.entry-content h1 { font-size: 40px; }
.entry-content h2 { font-size: 32px; }
.entry-content h3 { font-size: 24px; }
.entry-content a { color: var(--kmx-orange); text-decoration: underline; }
.entry-content a:hover { text-decoration: none; }
.entry-content blockquote {
  border-left: 4px solid var(--kmx-orange);
  padding: 16px 24px;
  background: var(--kmx-orange-soft);
  font-style: italic;
  border-radius: 0 12px 12px 0;
}
.entry-content code {
  background: var(--kmx-ink);
  color: var(--kmx-orange);
  padding: 2px 8px;
  border-radius: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.9em;
}
.entry-content ul, .entry-content ol { padding-left: 24px; }

/* ============================================================
   BUTTONS (allgemein)
   ============================================================ */
.btn-primary, .btn-secondary {
  padding: 18px 36px;
  border-radius: 999px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  transition: all 0.3s;
  cursor: pointer;
}
.btn-primary { background: var(--kmx-orange); color: var(--kmx-white); }
.btn-primary:hover {
  background: var(--kmx-ink); color: var(--kmx-white);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(255, 94, 26, 0.3);
}
.btn-secondary {
  background: transparent;
  color: var(--kmx-ink);
  border: 1.5px solid var(--kmx-ink);
}
.btn-secondary:hover { background: var(--kmx-ink); color: var(--kmx-white); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: var(--kmx-ink);
  color: var(--kmx-white);
  padding: 80px 48px 40px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 60px;
  margin-bottom: 60px;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}
.footer-logo {
  font-family: 'Archivo Black', sans-serif;
  font-size: 32px;
  margin-bottom: 16px;
  letter-spacing: -0.02em;
  color: var(--kmx-white);
}
.footer-logo .mark { color: var(--kmx-orange); font-size: 40px; }
.footer-tagline { color: rgba(255, 255, 255, 0.6); max-width: 320px; line-height: 1.6; margin: 0; }

.site-footer h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin: 0 0 20px;
  color: var(--kmx-orange);
}
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin-bottom: 10px; }
.site-footer a {
  color: rgba(255, 255, 255, 0.7);
  font-size: 14px;
  transition: color 0.2s;
}
.site-footer a:hover { color: var(--kmx-orange); }

.footer-bottom {
  padding: 32px 0 0;
  max-width: 1400px;
  margin: 0 auto;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.footer-legal a {
  color: rgba(255, 255, 255, 0.5);
  transition: color 0.2s;
}
.footer-legal a:hover {
  color: var(--kmx-orange);
}

/* ============================================================
   WOOCOMMERCE
   ============================================================ */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 24px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  background: var(--kmx-white);
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--kmx-line);
  transition: transform 0.4s, box-shadow 0.4s;
  position: relative;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 48px rgba(255, 94, 26, 0.15);
}
.woocommerce ul.products li.product a {
  text-decoration: none !important;
  color: inherit !important;
}
.woocommerce ul.products li.product img {
  margin: 0 !important;
  aspect-ratio: 1;
  object-fit: cover;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  padding: 20px 20px 4px !important;
  font-family: 'Bricolage Grotesque', sans-serif !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--kmx-ink) !important;
}
.woocommerce ul.products li.product .price {
  padding: 0 20px 20px !important;
  font-family: 'Archivo Black', sans-serif !important;
  font-size: 22px !important;
  color: var(--kmx-orange) !important;
  letter-spacing: -0.02em !important;
  display: block !important;
}
.woocommerce ul.products li.product .price del {
  font-family: 'Bricolage Grotesque', sans-serif !important;
  color: var(--kmx-grey) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  margin-right: 8px;
}
.woocommerce span.onsale {
  position: absolute !important;
  top: 16px; left: 16px;
  background: #d40000 !important;
  color: var(--kmx-white) !important;
  border-radius: 999px !important;
  padding: 6px 12px !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  margin: 0 !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1 !important;
  z-index: 2;
}
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce ul.products li.product .button {
  background: var(--kmx-orange) !important;
  color: var(--kmx-white) !important;
  border-radius: 999px !important;
  padding: 12px 24px !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  font-weight: 400 !important;
  border: none !important;
  transition: all 0.2s !important;
  margin: 0 20px 20px !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover { background: var(--kmx-ink) !important; }
.woocommerce a.button.alt,
.woocommerce button.button.alt { background: var(--kmx-ink) !important; }
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover { background: var(--kmx-orange-deep) !important; }

/* Single Product */
.woocommerce div.product .product_title {
  font-family: 'Archivo Black', sans-serif !important;
  font-size: clamp(36px, 5vw, 56px) !important;
  letter-spacing: -0.03em !important;
  line-height: 1 !important;
  margin-bottom: 16px !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: 'Archivo Black', sans-serif !important;
  color: var(--kmx-orange) !important;
  font-size: 32px !important;
  letter-spacing: -0.02em !important;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--kmx-grey);
  line-height: 1.7;
  margin: 24px 0;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-bottom: 1px solid var(--kmx-line) !important;
  padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 32px 0 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  padding: 16px 0 !important;
  color: var(--kmx-grey) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--kmx-orange) !important;
  border-bottom: 2px solid var(--kmx-orange);
}

/* Quantity / Inputs / Selects */
.woocommerce .quantity .qty,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 1px solid var(--kmx-line) !important;
  border-radius: 12px !important;
  padding: 14px 16px !important;
  font-family: inherit !important;
  font-size: 15px !important;
  background: var(--kmx-off-white) !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  outline: none;
  border-color: var(--kmx-orange) !important;
  background: var(--kmx-white) !important;
}

/* Tables */
.woocommerce table.shop_table {
  border: 1px solid var(--kmx-line) !important;
  border-radius: 16px !important;
  border-collapse: separate !important;
  overflow: hidden;
}
.woocommerce table.shop_table th {
  font-family: 'JetBrains Mono', monospace !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  font-size: 12px !important;
  background: var(--kmx-off-white) !important;
}

/* Messages */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: 16px !important;
  border-top-color: var(--kmx-orange) !important;
  background: var(--kmx-white) !important;
}
.woocommerce-message::before,
.woocommerce-info::before { color: var(--kmx-orange) !important; }

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  background: var(--kmx-ink) !important;
  font-size: 14px !important;
  padding: 18px !important;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover { background: var(--kmx-orange) !important; }

/* WooCommerce Wrapper aus Theme */
.woocommerce { padding: 0; }

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-area {
  max-width: 720px;
  margin: 60px auto;
  padding: 0 24px;
}
.comments-area h2, .comments-area h3 {
  font-family: 'Archivo Black', sans-serif;
  letter-spacing: -0.02em;
}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--kmx-line);
  border-radius: 12px;
  font-family: inherit;
  font-size: 15px;
  background: var(--kmx-off-white);
}
.comment-form input:focus, .comment-form textarea:focus {
  outline: none;
  border-color: var(--kmx-orange);
}
.comment-form-comment label,
.comment-form-author label,
.comment-form-email label,
.comment-form-url label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--kmx-grey);
  display: block;
  margin-bottom: 8px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .site-header { padding: 16px 24px; }
  .main-nav { display: none; }
  .menu-toggle { display: flex; }
  .page-header { padding: 100px 24px 40px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .site-footer { padding: 60px 24px 32px; }
  .entry-content { padding: 40px 24px; }
}
@media (max-width: 600px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}
