/*
Theme Name: M2 Shop Theme V2
Theme URI: https://shop.m2teknoloji.com
Author: M2 Teknoloji
Description: M2 Teknoloji kurumsal shop / WooCommerce teması. V2 küçük ürün kartları ve daha kompakt mağaza görünümü.
Version: 2.0
Text Domain: m2-shop
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 8.0
*/

:root {
  --m2-navy: #071b34;
  --m2-navy-2: #0b2342;
  --m2-blue: #0b5cab;
  --m2-cyan: #22b8cf;
  --m2-bg: #f5f7fb;
  --m2-card: #ffffff;
  --m2-text: #172033;
  --m2-muted: #6b7280;
  --m2-border: #e5e7eb;
  --m2-soft: #eef6ff;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  background: var(--m2-bg);
  color: var(--m2-text);
}

a { color: inherit; text-decoration: none; }

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

.m2-shop-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(7, 27, 52, 0.96);
  backdrop-filter: blur(12px);
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.m2-shop-header-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 15px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}

.m2-shop-logo { display: flex; flex-direction: column; line-height: 1.1; }
.m2-shop-logo strong { font-size: 22px; letter-spacing: .4px; }
.m2-shop-logo span { font-size: 12px; color: #b8d8ff; margin-top: 4px; }

.m2-shop-nav {
  display: flex;
  align-items: center;
  gap: 17px;
  font-size: 14px;
  white-space: nowrap;
}

.m2-shop-nav a { color: #eaf4ff; opacity: .95; }
.m2-shop-nav a:hover { color: #fff; }

.m2-shop-cta {
  background: linear-gradient(135deg, var(--m2-blue), var(--m2-cyan));
  color: #fff !important;
  padding: 10px 15px;
  border-radius: 999px;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(34,184,207,.22);
}

.m2-shop-top {
  background:
    radial-gradient(circle at top right, rgba(34,184,207,.32), transparent 32%),
    radial-gradient(circle at 10% 20%, rgba(11,92,171,.55), transparent 30%),
    linear-gradient(135deg, #071b34 0%, #0d315d 58%, #0b5cab 100%);
  color: #fff;
  overflow: hidden;
}

.m2-shop-top-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 46px 22px 40px;
}

.m2-shop-kicker {
  display: inline-flex;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  color: #d8efff;
  font-size: 13px;
  margin-bottom: 14px;
  border: 1px solid rgba(255,255,255,.12);
}

.m2-shop-top h1 {
  font-size: clamp(30px, 4vw, 48px);
  margin: 0 0 12px;
  max-width: 820px;
  letter-spacing: -0.03em;
}

.m2-shop-top p {
  max-width: 760px;
  color: #d9e8f7;
  font-size: 17px;
  line-height: 1.65;
  margin: 0;
}

.m2-shop-main {
  max-width: 1240px;
  margin: 0 auto;
  padding: 34px 22px 56px;
}

.m2-shop-category-strip {
  max-width: 1240px;
  margin: -22px auto 0;
  padding: 0 22px;
  position: relative;
  z-index: 5;
}

.m2-shop-category-box {
  background: #fff;
  border: 1px solid var(--m2-border);
  border-radius: 22px;
  box-shadow: 0 16px 42px rgba(7,27,52,.10);
  padding: 16px;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.m2-shop-cat-link {
  background: var(--m2-soft);
  border: 1px solid #dbeafe;
  border-radius: 15px;
  padding: 12px;
  color: var(--m2-navy);
  font-size: 13px;
  font-weight: 700;
  text-align: center;
}

.m2-shop-cat-link:hover { background: #dff2ff; color: var(--m2-blue); }

.woocommerce .woocommerce-breadcrumb {
  color: var(--m2-muted);
  font-size: 13px;
  margin-bottom: 18px;
}

.woocommerce-products-header__title,
.woocommerce h1.page-title {
  color: var(--m2-navy);
  letter-spacing: -0.02em;
}

.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
  padding: 0;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none; }

.woocommerce ul.products li.product {
  width: auto !important;
  float: none !important;
  margin: 0 !important;
  background: var(--m2-card);
  border: 1px solid var(--m2-border);
  border-radius: 20px;
  padding: 16px !important;
  box-shadow: 0 12px 30px rgba(7,27,52,.07);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  overflow: hidden;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 42px rgba(7,27,52,.12);
  border-color: #c7dff5;
}

.woocommerce ul.products li.product a img {
  border-radius: 14px;
  background: #f1f5f9;
  margin-bottom: 13px;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--m2-text);
  font-size: 16px;
  line-height: 1.35;
  min-height: 44px;
  padding: 0;
}

.woocommerce ul.products li.product .price {
  color: var(--m2-blue);
  font-weight: 800;
  font-size: 15px;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background: var(--m2-blue) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 11px 16px !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover { background: #063f7a !important; }

.woocommerce-result-count,
.woocommerce-ordering { margin-bottom: 22px !important; }

.woocommerce .quantity .qty {
  border: 1px solid var(--m2-border);
  border-radius: 10px;
  padding: 8px;
}

.woocommerce div.product {
  background: #fff;
  border: 1px solid var(--m2-border);
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 12px 30px rgba(7,27,52,.07);
}

.woocommerce div.product div.images img { border-radius: 18px; }
.woocommerce div.product .product_title { color: var(--m2-navy); }
.woocommerce div.product p.price, .woocommerce div.product span.price { color: var(--m2-blue); font-weight: 800; }

.m2-shop-footer {
  background: #06162b;
  color: #cbd5e1;
  padding: 28px 22px;
  font-size: 14px;
}

.m2-shop-footer-inner {
  max-width: 1240px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.m2-shop-footer a { color: #e2e8f0; }
.m2-shop-footer a:hover { color: #fff; }

@media (max-width: 1100px) {
  .m2-shop-header-inner { align-items: flex-start; flex-direction: column; }
  .m2-shop-nav { flex-wrap: wrap; white-space: normal; }
  .woocommerce ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .m2-shop-category-box { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .m2-shop-category-box { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 520px) {
  .woocommerce ul.products { grid-template-columns: 1fr; }
  .m2-shop-category-box { grid-template-columns: 1fr; }
}


/* ===== M2 SHOP V2 - Compact catalog layout ===== */
body.woocommerce,
body.woocommerce-page {
  overflow-x: hidden;
}

body.woocommerce .woocommerce-products-header,
body.woocommerce .woocommerce-notices-wrapper,
body.woocommerce nav.woocommerce-pagination {
  width: min(1240px, calc(100% - 44px));
  margin-left: auto !important;
  margin-right: auto !important;
}

body.woocommerce .woocommerce-result-count,
body.woocommerce .woocommerce-ordering {
  display: none !important;
}

body.woocommerce .woocommerce-products-header__title,
body.woocommerce h1.page-title {
  font-size: 28px;
  margin: 0 0 18px !important;
}

body.woocommerce ul.products,
body.woocommerce-page ul.products {
  width: min(1240px, calc(100% - 44px));
  margin-left: auto !important;
  margin-right: auto !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 16px !important;
  padding: 0 !important;
}

body.woocommerce ul.products li.product,
body.woocommerce-page ul.products li.product {
  width: auto !important;
  min-width: 0 !important;
  float: none !important;
  clear: none !important;
  margin: 0 !important;
  border-radius: 16px !important;
  padding: 12px !important;
  box-shadow: 0 8px 22px rgba(7,27,52,.06) !important;
}

body.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
body.woocommerce-page ul.products li.product a.woocommerce-LoopProduct-link {
  display: block;
}

body.woocommerce ul.products li.product a img,
body.woocommerce-page ul.products li.product a img {
  width: 100% !important;
  height: 145px !important;
  object-fit: contain !important;
  padding: 14px !important;
  background: #f8fafc !important;
  border: 1px solid #edf2f7 !important;
  border-radius: 13px !important;
  margin: 0 0 10px !important;
}

body.woocommerce ul.products li.product .woocommerce-loop-product__title,
body.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
  font-size: 14px !important;
  line-height: 1.35 !important;
  min-height: 38px !important;
  margin: 0 0 8px !important;
}

body.woocommerce ul.products li.product .button,
body.woocommerce-page ul.products li.product .button {
  font-size: 13px !important;
  padding: 9px 13px !important;
  margin-top: 8px !important;
}

body.woocommerce ul.products li.product .price,
body.woocommerce-page ul.products li.product .price {
  display: none !important;
}

.m2-shop-main {
  width: min(1240px, calc(100% - 44px));
  max-width: 1240px;
  padding: 30px 0 52px;
}

.m2-shop-category-strip {
  margin-top: -20px;
}

.m2-shop-category-box {
  padding: 12px;
  gap: 9px;
}

.m2-shop-cat-link {
  padding: 10px 8px;
  font-size: 12.5px;
}

@media (max-width: 1240px) {
  body.woocommerce ul.products,
  body.woocommerce-page ul.products {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 920px) {
  body.woocommerce ul.products,
  body.woocommerce-page ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 680px) {
  body.woocommerce ul.products,
  body.woocommerce-page ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  body.woocommerce ul.products li.product a img,
  body.woocommerce-page ul.products li.product a img {
    height: 130px !important;
  }
}

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