/*
Theme Name:   SolGem Child
Theme URI:    https://solgem.hu
Description:  SolGem kézműves ásványékszer webshop — Storefront child theme
Author:       SolGem
Author URI:   https://solgem.hu
Template:     storefront
Version:      1.0.0
License:      GNU General Public License v2 or later
License URI:  LICENSE
Text Domain:  solgem-child
*/

/* ============================================================
   CSS VÁLTOZÓK — SolGem Márkaidentitás
   ============================================================ */
:root {
  --gold:     #C9963E;
  --gold-lt:  #E8C97A;
  --olive:    #4A5020;
  --olive-lt: #6B7A2E;
  --burgundy: #8B2E3F;
  --dark:     #1C0C06;
  --mid:      #5A4A3A;
  --bg:       #FAF7F2;
  --bg-warm:  #F5F0E8;
  --white:    #FFFFFF;
  --border:   rgba(201,150,62,0.25);
  --footer-bg:#1A1E0A;
  --hero-bg:  #FDFDE7;

  --font-serif: Georgia, 'Times New Roman', serif;
  --font-sans:  'Helvetica Neue', Arial, sans-serif;

  --radius:   6px;
  --shadow:   0 2px 12px rgba(28,12,6,0.08);
  --shadow-md:0 4px 24px rgba(28,12,6,0.12);
  --transition: 0.3s ease;
}

/* ============================================================
   ÁLTALÁNOS ALAPOK
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--font-sans);
  color: var(--dark);
  background: var(--bg);
  line-height: 1.65;
  font-size: 16px;
}

h1, h2, h3, h4 {
  font-family: var(--font-serif);
  color: var(--dark);
  line-height: 1.25;
  font-weight: normal;
}

a {
  color: var(--olive);
  text-decoration: none;
  transition: color var(--transition);
}
a:hover { color: var(--gold); }

img { max-width: 100%; height: auto; display: block; }

/* ============================================================
   HEADER & NAVIGÁCIÓ
   ============================================================ */
.site-header {
  background: var(--bg) !important;
  border-bottom: 1px solid var(--border);
  padding: 0 !important;
}

.site-branding {
  padding: 16px 0;
}

.site-title a {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  font-weight: normal;
  color: var(--dark) !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.site-title a::after {
  content: ' ✦';
  color: var(--gold);
  font-size: 0.7em;
}

.site-description {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  color: var(--mid);
  text-transform: uppercase;
}

/* Navigáció */
.main-navigation a {
  font-family: var(--font-sans);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mid) !important;
  padding: 8px 14px !important;
  transition: color var(--transition);
}

.main-navigation a:hover,
.main-navigation .current-menu-item > a {
  color: var(--olive) !important;
}

/* Kosár ikon a fejlécben */
.site-header-cart .cart-contents {
  color: var(--dark);
  font-size: 0.85rem;
}

.site-header-cart .cart-contents:hover {
  color: var(--gold);
}

/* ============================================================
   GOMBOK
   ============================================================ */
.button,
button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  background: var(--gold) !important;
  color: var(--dark) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-family: var(--font-sans) !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 12px 28px !important;
  cursor: pointer !important;
  transition: background var(--transition), transform var(--transition) !important;
  display: inline-block !important;
}

.button:hover,
button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  background: var(--olive) !important;
  color: var(--white) !important;
  transform: translateY(-1px) !important;
}

/* Alt / outline gomb */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce #payment #place_order,
.woocommerce-page #payment #place_order {
  background: var(--olive) !important;
  color: var(--white) !important;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: var(--dark) !important;
}

/* ============================================================
   HERO SZEKCIÓ (főoldalon)
   ============================================================ */
.storefront-hero,
.storefront-full-width-featured {
  background: var(--hero-bg) !important;
  position: relative;
  overflow: hidden;
}

.storefront-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 30%, rgba(201,150,62,0.18) 0%, transparent 60%);
  pointer-events: none;
}

/* Hero szöveg */
.storefront-hero h1,
.storefront-hero h2,
.storefront-full-width-featured h1,
.storefront-full-width-featured h2 {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: var(--dark) !important;
  letter-spacing: 0.04em;
  line-height: 1.15;
}

.storefront-hero p,
.storefront-full-width-featured p {
  color: rgba(28,12,6,0.6) !important;
  font-size: 1.05rem;
}

/* ============================================================
   TERMÉK KÁRTYÁK
   ============================================================ */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 28px !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

.woocommerce ul.products li.product {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  padding: 0 !important;
  overflow: hidden !important;
  transition: box-shadow var(--transition), transform var(--transition) !important;
  position: relative !important;
}

.woocommerce ul.products li.product:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-4px) !important;
}

.woocommerce ul.products li.product a img {
  width: 100% !important;
  height: 260px !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform var(--transition) !important;
}

.woocommerce ul.products li.product:hover a img {
  transform: scale(1.04) !important;
}

/* Termék kártya tartalom */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  font-family: var(--font-serif) !important;
  font-size: 1.05rem !important;
  font-weight: normal !important;
  color: var(--dark) !important;
  padding: 16px 16px 4px !important;
  margin: 0 !important;
}

.woocommerce ul.products li.product .price {
  color: var(--gold) !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  padding: 0 16px 8px !important;
  display: block !important;
}

.woocommerce ul.products li.product .button {
  margin: 8px 16px 16px !important;
  width: calc(100% - 32px) !important;
  text-align: center !important;
}

/* Badge — Akció / Új */
.woocommerce span.onsale {
  background: var(--burgundy) !important;
  color: var(--white) !important;
  border-radius: 50% !important;
  width: 44px !important;
  height: 44px !important;
  line-height: 44px !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  top: 12px !important;
  left: 12px !important;
}

/* ============================================================
   TERMÉK RÉSZLETES OLDAL
   ============================================================ */
.woocommerce div.product .product_title {
  font-family: var(--font-serif) !important;
  font-size: clamp(1.6rem, 3vw, 2.4rem) !important;
  font-weight: normal !important;
  color: var(--dark) !important;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--gold) !important;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
}

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--mid);
  font-size: 0.95rem;
  line-height: 1.7;
  margin-bottom: 20px;
}

/* Termék meta (kategória, cimke) */
.woocommerce div.product .product_meta {
  font-size: 0.82rem;
  color: var(--mid);
  border-top: 1px solid var(--border);
  padding-top: 16px;
  margin-top: 20px;
}

.woocommerce div.product .product_meta a {
  color: var(--olive);
}

/* Mennyiség mező */
.woocommerce .quantity .qty {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 10px 12px !important;
  font-size: 0.95rem !important;
  color: var(--dark) !important;
  background: var(--white) !important;
  width: 72px !important;
}

/* Termék galéria */
.woocommerce div.product div.images .woocommerce-product-gallery__image img {
  border-radius: 10px;
  border: 1px solid var(--border);
}

/* ============================================================
   KOSÁR OLDAL
   ============================================================ */
.woocommerce table.cart {
  border-collapse: collapse;
  width: 100%;
}

.woocommerce table.cart th {
  font-family: var(--font-sans);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mid);
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-warm);
}

.woocommerce table.cart td {
  padding: 20px 16px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.woocommerce table.cart .product-name a {
  font-family: var(--font-serif);
  font-size: 1rem;
  color: var(--dark);
}

.woocommerce table.cart .product-price,
.woocommerce table.cart .product-subtotal {
  color: var(--gold);
  font-weight: 600;
}

/* Kosár összesítő */
.woocommerce .cart-collaterals .cart_totals {
  background: var(--bg-warm);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 28px;
}

.woocommerce .cart-collaterals .cart_totals h2 {
  font-size: 1.25rem;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

.woocommerce .cart-collaterals .cart_totals table th,
.woocommerce .cart-collaterals .cart_totals table td {
  padding: 10px 0;
  border-bottom: 1px solid rgba(201,150,62,0.15);
}

.woocommerce .cart-collaterals .cart_totals .order-total .amount {
  color: var(--gold) !important;
  font-size: 1.2rem !important;
  font-weight: 600 !important;
}

/* ============================================================
   CHECKOUT OLDAL
   ============================================================ */
.woocommerce form .form-row label {
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  color: var(--mid);
  font-weight: 500;
  margin-bottom: 4px;
  display: block;
}

.woocommerce form .form-row input,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 11px 14px !important;
  font-size: 0.95rem !important;
  color: var(--dark) !important;
  background: var(--white) !important;
  width: 100% !important;
  transition: border-color var(--transition) !important;
}

.woocommerce form .form-row input:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  outline: none !important;
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(201,150,62,0.15) !important;
}

#order_review {
  background: var(--bg-warm);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 28px;
}

#order_review h3 {
  font-size: 1.15rem;
  margin-bottom: 20px;
}

/* ============================================================
   WIDGET TERÜLET (SIDEBAR)
   ============================================================ */
.widget-area .widget {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 24px;
  margin-bottom: 24px;
}

.widget-area .widget-title {
  font-family: var(--font-serif);
  font-size: 1rem;
  font-weight: normal;
  color: var(--dark);
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}

/* Szűrő widgetek */
.woocommerce .widget_price_filter .price_slider_wrapper .ui-widget-content {
  background: var(--border) !important;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range,
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  background: var(--gold) !important;
}

/* ============================================================
   ÉRTESÍTÉSEK
   ============================================================ */
.woocommerce-message,
.woocommerce-info {
  border-top-color: var(--gold) !important;
  background: #FFF9ED !important;
  color: var(--dark) !important;
}

.woocommerce-error {
  border-top-color: var(--burgundy) !important;
  background: #FFF0F2 !important;
}

.woocommerce-message::before {
  color: var(--gold) !important;
}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.woocommerce .woocommerce-breadcrumb {
  font-size: 0.82rem;
  color: var(--mid);
  padding: 12px 0;
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--olive);
}

.woocommerce .woocommerce-breadcrumb a:hover {
  color: var(--gold);
}

/* ============================================================
   ÉRTÉKELÉSEK
   ============================================================ */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before {
  color: var(--gold) !important;
}

/* ============================================================
   KATEGÓRIA FEJLÉC
   ============================================================ */
.woocommerce-products-header {
  background: linear-gradient(135deg, #4A5020 0%, #5A6228 100%);
  padding: 60px 32px;
  border-radius: 10px;
  margin-bottom: 40px;
  text-align: center;
}

.woocommerce-products-header__title {
  font-family: var(--font-serif) !important;
  font-size: clamp(1.8rem, 4vw, 2.8rem) !important;
  color: var(--white) !important;
  letter-spacing: 0.06em !important;
  font-weight: normal !important;
}

.woocommerce-products-header .term-description {
  color: rgba(255,255,255,0.75) !important;
  max-width: 600px;
  margin: 0 auto;
}

/* ============================================================
   LAPOZÓ
   ============================================================ */
.woocommerce nav.woocommerce-pagination ul {
  border: none !important;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  color: var(--mid) !important;
  margin: 0 3px !important;
  padding: 8px 14px !important;
  transition: all var(--transition) !important;
}

.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--olive) !important;
  border-color: var(--olive) !important;
  color: var(--white) !important;
}

/* ============================================================
   LÁBLÉC
   ============================================================ */
.site-footer {
  background: var(--footer-bg) !important;
  color: rgba(255,255,255,0.65) !important;
  padding: 60px 0 0 !important;
}

.site-footer a {
  color: rgba(255,255,255,0.65) !important;
  transition: color var(--transition) !important;
}

.site-footer a:hover {
  color: var(--gold) !important;
}

.site-footer .widget-title {
  color: var(--white) !important;
  font-family: var(--font-serif) !important;
  font-size: 1rem !important;
  font-weight: normal !important;
  letter-spacing: 0.06em !important;
  margin-bottom: 16px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid rgba(201,150,62,0.25) !important;
}

.site-footer .site-info {
  background: rgba(0,0,0,0.3) !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.35) !important;
  font-size: 0.78rem !important;
  padding: 16px 0 !important;
  margin-top: 40px !important;
  text-align: center !important;
}

.site-footer .site-info a {
  color: rgba(255,255,255,0.35) !important;
}

/* Footer arany vonal a tetején */
.site-footer::before {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  margin-bottom: 0;
}

/* ============================================================
   KAPCSOLAT OLDAL (WP Contact Form)
   ============================================================ */
.wpcf7-form input,
.wpcf7-form textarea,
.wpcf7-form select {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 11px 14px !important;
  font-size: 0.95rem !important;
  color: var(--dark) !important;
  background: var(--white) !important;
  width: 100% !important;
  transition: border-color var(--transition) !important;
}

.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
  outline: none !important;
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(201,150,62,0.15) !important;
}

/* ============================================================
   RESZPONZÍV
   ============================================================ */
@media (max-width: 900px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 600px) {
  .woocommerce ul.products {
    grid-template-columns: 1fr !important;
  }

  .site-title a {
    font-size: 1.4rem;
  }

  .woocommerce div.product .product_title {
    font-size: 1.4rem !important;
  }
}
