/*
Theme Name:  Defne İş Güvenliği
Theme URI:   https://defneisguvenligi.com
Description: Defne İş Güvenliği Ekipmanları - Özel WooCommerce Teması
Version:     1.0.0
Author:      Defne İSG
Text Domain: defne
Tags:        woocommerce, e-commerce, custom
*/

/* ============================================================
   CSS VARIABLES
   ============================================================ */
:root {
	--color-primary:     #1a5c2e;
	--color-primary-dk:  #134422;
	--color-primary-lt:  #2d7a42;
	--color-accent:      #25d366;
	--color-text:        #222;
	--color-text-light:  #666;
	--color-border:      #e0e0e0;
	--color-bg:          #f8f8f8;
	--color-white:       #fff;
	--radius:            8px;
	--shadow:            0 2px 12px rgba(0,0,0,.08);
	--transition:        .2s ease;
	--container:         1280px;
	--font:              'Segoe UI', system-ui, -apple-system, sans-serif;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
	font-family: var(--font);
	color: var(--color-text);
	background: var(--color-white);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }

/* ============================================================
   CONTAINER
   ============================================================ */
.container {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 20px;
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
	background: var(--color-white);
	box-shadow: 0 2px 8px rgba(0,0,0,.07);
	position: sticky;
	top: 0;
	z-index: 1000;
}

.header-main {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	padding: 16px 0;
}

/* Sol blok: logo + iletişim yan yana */
.header-left {
	display: flex;
	align-items: center;
	gap: 28px;
	flex-shrink: 0;
}

/* Logo */
.site-logo {
	flex-shrink: 0;
}
.site-logo img,
.site-logo a img {
	height: 72px !important;
	width: auto !important;
	max-width: 220px;
}
.site-logo-text {
	font-size: 26px;
	font-weight: 800;
	color: var(--color-primary);
	line-height: 1.15;
	white-space: nowrap;
}
.site-logo-text span {
	display: block;
	font-size: 11px;
	font-weight: 400;
	color: var(--color-text-light);
	letter-spacing: .5px;
	margin-top: 2px;
}

/* İletişim — logonun sağında */
.header-contact {
	display: flex;
	flex-direction: column;
	gap: 5px;
	font-size: 13px;
	border-left: 2px solid var(--color-border);
	padding-left: 24px;
}
.header-contact a {
	display: flex;
	align-items: center;
	gap: 7px;
	color: var(--color-text);
	font-weight: 500;
	transition: color var(--transition);
	white-space: nowrap;
}
.header-contact a:hover { color: var(--color-primary); }
.header-contact svg { width: 15px; height: 15px; flex-shrink: 0; color: var(--color-primary); }

/* Arama — sağa yaslanır, genişler */
.header-search {
	flex: 1;
	max-width: 520px;
	margin-left: auto;
}
.search-form {
	display: flex;
	border: 2px solid var(--color-border);
	border-radius: 50px;
	overflow: hidden;
	transition: border-color var(--transition);
}
.search-form:focus-within {
	border-color: var(--color-primary);
}
.search-form input {
	flex: 1;
	border: none;
	outline: none;
	padding: 11px 18px;
	font-size: 14px;
	font-family: var(--font);
	background: transparent;
}
.search-form button {
	background: var(--color-primary);
	border: none;
	color: #fff;
	padding: 11px 22px;
	cursor: pointer;
	font-size: 16px;
	transition: background var(--transition);
}
.search-form button:hover { background: var(--color-primary-dk); }

/* Nav */
.header-nav {
	background: var(--color-primary);
}
.nav-menu {
	display: flex;
	align-items: center;
	gap: 0;
}
.nav-menu li { position: relative; }
.nav-menu a {
	display: block;
	padding: 13px 18px;
	color: rgba(255,255,255,.9);
	font-size: 14px;
	font-weight: 500;
	transition: background var(--transition), color var(--transition);
	white-space: nowrap;
}
.nav-menu a:hover,
.nav-menu .current-menu-item > a {
	background: rgba(255,255,255,.15);
	color: #fff;
}

/* Dropdown */
.nav-menu .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: #fff;
	min-width: 220px;
	box-shadow: var(--shadow);
	border-radius: 0 0 var(--radius) var(--radius);
	z-index: 100;
}
.nav-menu li:hover > .sub-menu { display: block; }
.nav-menu .sub-menu a {
	padding: 10px 18px;
	color: var(--color-text);
	border-bottom: 1px solid var(--color-border);
}
.nav-menu .sub-menu a:hover {
	background: var(--color-bg);
	color: var(--color-primary);
}

/* ============================================================
   MOBİL HAMBURGER MENÜ
   ============================================================ */
.nav-container {
	display: flex;
	align-items: center;
	position: relative;
}

.mobile-menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 10px 16px;
	margin-right: auto;
	z-index: 1100;
}
.mobile-menu-toggle span {
	display: block;
	width: 24px;
	height: 2px;
	background: #fff;
	border-radius: 2px;
	transition: transform .3s ease, opacity .3s ease;
	transform-origin: center;
}
/* Hamburger → X animasyonu */
.mobile-menu-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-menu-toggle.active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.mobile-menu-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Karartma overlay */
.mobile-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,.5);
	z-index: 999;
	opacity: 0;
	transition: opacity .3s ease;
}
.mobile-overlay.active {
	display: block;
	opacity: 1;
}

/* ============================================================
   HERO SLIDER — tam sayfa genişliği
   ============================================================ */
.hero-slider {
	position: relative;
	width: 100vw;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	margin-top: 0;
	overflow: hidden;
	background: var(--color-primary);
}

/* nav ile slider arasında boşluk olmasın */
.site-header {
	margin-bottom: 0 !important;
}
.header-nav {
	margin-bottom: 0 !important;
}

.hero-slides {
	width: 100%;
}

@keyframes slideIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

/* Slide — tam genişlik, yatay split */
.hero-slide {
	display: none;
	width: 100%;
	height: 420px;
	animation: slideIn .5s ease;
}
.hero-slide.active {
	display: flex !important;
	align-items: center;
	justify-content: center;
}

/* İçerik sarmalayıcı — max genişlik, ortalı */
.hero-slide > .hero-text,
.hero-slide > .hero-collage {
	/* max-width toplam ~1100px içinde */
}

/* Sol: Metin */
.hero-text {
	flex: 0 0 400px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 0 52px 0 36px;
	color: #fff;
}
.hero-text h1 {
	font-size: 36px;
	font-weight: 900;
	line-height: 1.2;
	margin-bottom: 12px;
	text-shadow: 0 2px 10px rgba(0,0,0,.3);
	letter-spacing: -.3px;
}
.hero-text p {
	font-size: 15px;
	opacity: .82;
	margin-bottom: 30px;
	line-height: 1.75;
	max-width: 310px;
	font-weight: 400;
}

/* Sağ: 2×2 ürün kolajı */
.hero-collage {
	flex: 0 0 520px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 10px;
	padding: 28px 0;
	height: 100%;
	box-sizing: border-box;
}
.hero-collage-item {
	background: rgba(255,255,255,.93);
	border-radius: 12px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: transform .3s ease, box-shadow .3s;
}
.hero-collage-item:hover {
	background: #fff;
	transform: translateY(-3px);
	box-shadow: 0 8px 20px rgba(0,0,0,.2);
}
.hero-collage-item img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 14px;
}
.hero-btn {
	display: inline-block;
	background: #fff;
	color: var(--color-primary);
	padding: 13px 34px;
	border-radius: 6px;
	font-weight: 700;
	font-size: 14px;
	letter-spacing: .3px;
	transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
	box-shadow: 0 4px 16px rgba(0,0,0,.2);
	align-self: flex-start;
}
.hero-btn:hover {
	background: #f0f8f2;
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0,0,0,.28);
	color: var(--color-primary-dk);
}

/* Oklar */
.slider-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(255,255,255,.2);
	border: 2px solid rgba(255,255,255,.5);
	color: #fff;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	font-size: 18px;
	cursor: pointer;
	z-index: 10;
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	transition: background var(--transition);
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}
.slider-arrow:hover { background: rgba(255,255,255,.4); }
.slider-prev { left: 20px; }
.slider-next { right: 20px; }

/* Noktalar */
.slider-dots {
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 8px;
	z-index: 10;
}
.slider-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: 2px solid #fff;
	background: transparent;
	cursor: pointer;
	transition: background var(--transition);
	padding: 0;
}
.slider-dot.active { background: #fff; }

/* ============================================================
   SECTION TITLES
   ============================================================ */
.section-title {
	font-size: 24px;
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: 24px;
	padding-bottom: 10px;
	border-bottom: 3px solid var(--color-primary);
	display: inline-block;
}

/* ============================================================
   CATEGORY GRID
   ============================================================ */
.categories-section { padding: 48px 0 32px; }

.category-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 16px;
}

.category-card {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: 20px 12px;
	text-align: center;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
	cursor: pointer;
}
.category-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow);
	border-color: var(--color-primary);
}
.category-card img {
	width: 64px;
	height: 64px;
	object-fit: contain;
	margin: 0 auto 10px;
}
.category-card .cat-icon {
	font-size: 40px;
	margin-bottom: 10px;
	display: block;
}
.category-card span {
	font-size: 13px;
	font-weight: 600;
	color: var(--color-text);
	display: block;
	line-height: 1.3;
}

/* ============================================================
   PRODUCT GRID
   ============================================================ */
.products-section { padding: 32px 0 56px; }

/* Reset WooCommerce float layout */
ul.products::before,
ul.products::after { display: none !important; }

ul.products li.product,
ul.products li.product.first,
ul.products li.product.last {
	float: none !important;
	clear: none !important;
	margin: 0 !important;
	width: auto !important;
}

ul.products,
.products-grid {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr) !important;
	gap: 24px !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 0 32px !important;
	clear: both !important;
}

/* WooCommerce Product Card */
ul.products li.product,
.product-card {
	background: #ffffff;
	border: 1px solid #e8e8e8;
	border-radius: 10px;
	overflow: hidden;
	transition: transform var(--transition), box-shadow var(--transition);
	position: relative;
	display: flex !important;
	flex-direction: column !important;
	box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
ul.products li.product:hover,
.product-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 10px 28px rgba(0,0,0,.11);
	border-color: #d0d0d0;
}

/* Product image — açık gri/kirli beyaz arka plan */
ul.products li.product a.woocommerce-loop-product__link {
	display: block !important;
	overflow: hidden;
	background: #ffffff;
}
ul.products li.product a img,
ul.products li.product img,
.product-card img {
	width: 100% !important;
	height: 210px !important;
	object-fit: contain !important;
	padding: 20px !important;
	background: #ffffff !important;
	transition: transform .35s ease !important;
	display: block !important;
}
ul.products li.product:hover a img { transform: scale(1.07); }

/* Görsel altı — kart gövdesi net beyaz */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .price,
ul.products li.product .button {
	background: #ffffff;
}

/* Title */
ul.products li.product .woocommerce-loop-product__title,
.product-card h3 {
	font-size: 14px !important;
	font-weight: 600 !important;
	padding: 12px 14px 6px !important;
	color: var(--color-text) !important;
	line-height: 1.4 !important;
	flex: 1 !important;
}

/* Price */
ul.products li.product .price,
.product-price {
	padding: 0 14px 10px !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	color: var(--color-primary) !important;
	display: block !important;
}
ul.products li.product .price del {
	color: #bbb !important;
	font-size: 12px !important;
	margin-right: 6px !important;
	font-weight: 400 !important;
}

/* Add to cart button */
ul.products li.product .button,
ul.products li.product a.button,
ul.products li.product .add_to_cart_button,
.product-card .btn-cart {
	display: block !important;
	margin: auto 14px 14px !important;
	background: var(--color-primary) !important;
	color: #fff !important;
	padding: 10px 14px !important;
	border-radius: var(--radius) !important;
	text-align: center !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	border: none !important;
	cursor: pointer !important;
	transition: background var(--transition) !important;
	text-decoration: none !important;
	line-height: 1.4 !important;
}
ul.products li.product .button:hover,
ul.products li.product a.button:hover { background: var(--color-primary-dk) !important; color: #fff !important; }

/* Sale badge */
ul.products li.product .onsale {
	background: #e53935 !important;
	color: #fff !important;
	border-radius: 50px !important;
	padding: 3px 10px !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	position: absolute;
	top: 10px;
	left: 10px;
	z-index: 1;
}

/* ============================================================
   İLETİŞİM SAYFASI
   ============================================================ */
.contact-page-wrap {
	padding: 48px 20px 72px;
}
.contact-page-title {
	font-size: 30px;
	font-weight: 800;
	color: var(--color-primary);
	margin-bottom: 36px;
	padding-bottom: 12px;
	border-bottom: 3px solid var(--color-primary);
	display: inline-block;
}
.contact-grid {
	display: grid;
	grid-template-columns: 380px 1fr;
	gap: 36px;
	align-items: start;
}

/* Bilgi kartları */
.contact-info-col {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.contact-card {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	background: #f7f9f7;
	border: 1px solid #e4ece4;
	border-radius: 10px;
	padding: 18px 20px;
	transition: box-shadow var(--transition), transform var(--transition);
}
.contact-card:hover {
	box-shadow: 0 4px 16px rgba(0,0,0,.07);
	transform: translateY(-2px);
}
.contact-card-icon {
	flex-shrink: 0;
	width: 42px;
	height: 42px;
	background: var(--color-primary);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.contact-card-icon svg {
	width: 22px;
	height: 22px;
	fill: #fff;
}
.contact-card strong {
	display: block;
	font-size: 13px;
	font-weight: 700;
	color: var(--color-primary);
	margin-bottom: 4px;
	text-transform: uppercase;
	letter-spacing: .5px;
}
.contact-card p {
	font-size: 14px;
	color: #444;
	line-height: 1.65;
	margin: 0;
}
.contact-card p a {
	color: #444;
	font-weight: 500;
}
.contact-card p a:hover { color: var(--color-primary); text-decoration: underline; }

/* Sağ kolon */
.contact-right-col {
	display: flex;
	flex-direction: column;
	gap: 28px;
}

/* Harita */
.contact-map {
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0,0,0,.1);
	height: 320px;
}
.contact-map iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}

/* CF7 Form */
.contact-form-wrap {
	background: #f7f9f7;
	border: 1px solid #e4ece4;
	border-radius: 12px;
	padding: 28px 28px 24px;
}
.contact-form-wrap h2 {
	font-size: 20px;
	font-weight: 700;
	color: var(--color-primary);
	margin-bottom: 20px;
}
.contact-form-wrap .wpcf7-form label {
	font-size: 13px;
	font-weight: 600;
	color: #555;
	display: block;
	margin-bottom: 4px;
}
.contact-form-wrap .wpcf7-form input[type="text"],
.contact-form-wrap .wpcf7-form input[type="email"],
.contact-form-wrap .wpcf7-form input[type="tel"],
.contact-form-wrap .wpcf7-form textarea {
	width: 100%;
	border: 1px solid #dde8dd;
	border-radius: 7px;
	padding: 10px 14px;
	font-size: 14px;
	font-family: var(--font);
	color: var(--color-text);
	background: #fff;
	margin-bottom: 14px;
	transition: border-color var(--transition);
	box-sizing: border-box;
}
.contact-form-wrap .wpcf7-form input:focus,
.contact-form-wrap .wpcf7-form textarea:focus {
	border-color: var(--color-primary);
	outline: none;
}
.contact-form-wrap .wpcf7-form textarea { height: 120px; resize: vertical; }
.contact-form-wrap .wpcf7-form .wpcf7-submit {
	background: var(--color-primary);
	color: #fff;
	border: none;
	padding: 12px 32px;
	border-radius: 7px;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: background var(--transition);
}
.contact-form-wrap .wpcf7-form .wpcf7-submit:hover { background: var(--color-primary-dk); }

/* Responsive */
@media (max-width: 900px) {
	.contact-grid { grid-template-columns: 1fr; }
	.contact-map { height: 260px; }
}

/* ============================================================
   BREADCRUMB — tüm sayfalarda
   ============================================================ */
.woocommerce-breadcrumb {
	background: #f4f7f4;
	padding: 10px 0;
	font-size: 13px;
	color: var(--color-text-light);
	border-bottom: 1px solid var(--color-border);
	display: block;
	width: 100vw;
	left: 50%;
	position: relative;
	margin-left: -50vw;
	margin-right: -50vw;
	margin-bottom: 0;
	box-sizing: border-box;
	padding-left: calc((100vw - min(1280px, 100vw)) / 2 + 20px);
	padding-right: calc((100vw - min(1280px, 100vw)) / 2 + 20px);
}
.woocommerce-breadcrumb a { color: var(--color-primary); }
.woocommerce-breadcrumb a:hover { text-decoration: underline; }
.woocommerce-breadcrumb .breadcrumb-separator,
.woocommerce-breadcrumb span.sep { color: #bbb; margin: 0 6px; }

/* ============================================================
   MAĞAZA / KATEGORİ SAYFASI
   ============================================================ */
.woo-wrapper {
	padding: 28px 20px 60px;
}

/* Mağaza başlığı */
.woocommerce-products-header {
	margin-bottom: 20px;
}
.woocommerce-products-header__title,
.woocommerce-loop-category__title {
	font-size: 24px;
	font-weight: 800;
	color: var(--color-text);
	margin-bottom: 4px;
}

/* Sonuç sayısı + sıralama */
.woocommerce-result-count {
	font-size: 13px;
	color: var(--color-text-light);
	margin-bottom: 0;
}
.woocommerce-ordering {
	margin-bottom: 0;
}
.woocommerce-ordering select {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: 8px 36px 8px 12px;
	font-size: 13px;
	font-family: var(--font);
	color: var(--color-text);
	background: #fff;
	outline: none;
	cursor: pointer;
	appearance: auto;
}

/* Araçlar çubuğu (üst) */
.woocommerce-result-count,
.woocommerce-ordering {
	display: inline-block;
}
.woocommerce .woocommerce-products-header + .woocommerce-notices-wrapper + form,
.woocommerce-page .woocommerce-products-header + form {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 0;
	border-bottom: 1px solid var(--color-border);
	margin-bottom: 24px;
}

/* Araçlar üst toolbar */
.woocommerce .woocommerce-products-header,
.woocommerce-page .woocommerce-products-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 0 16px;
	border-bottom: 2px solid var(--color-border);
	margin-bottom: 24px;
}
nav.woocommerce-breadcrumb + .woocommerce-products-header { border-top: none; }

/* Mağaza toolbarı */
.woocommerce .woocommerce-MyAccount-content,
.woocommerce-page form.woocommerce-ordering {
	margin-bottom: 20px;
}

/* Sayfalama */
.woocommerce nav.woocommerce-pagination {
	margin-top: 36px;
	text-align: center;
}
.woocommerce nav.woocommerce-pagination ul {
	display: inline-flex;
	gap: 6px;
	list-style: none;
	padding: 0;
	margin: 0;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: block;
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius) !important;
	padding: 8px 16px !important;
	font-size: 14px !important;
	color: var(--color-text) !important;
	background: #fff !important;
	transition: all var(--transition);
	text-decoration: none;
}
.woocommerce nav.woocommerce-pagination ul li a:hover {
	border-color: var(--color-primary) !important;
	color: var(--color-primary) !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--color-primary) !important;
	color: #fff !important;
	border-color: var(--color-primary) !important;
}

/* Arama sonuçları başlığı */
.woocommerce-products-header .page-title { font-size: 22px; font-weight: 700; }

/* ============================================================
   MARKALAR BÖLÜMÜ
   ============================================================ */
.brands-section {
	padding: 48px 0;
	background: #f4f7f4;
}
.brands-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 16px;
	margin-top: 24px;
}
.brand-card {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: 20px 16px;
	text-align: center;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.brand-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow);
	border-color: var(--color-primary);
}
.brand-name {
	font-size: 22px;
	font-weight: 900;
	color: var(--color-primary);
	letter-spacing: -0.5px;
	margin-bottom: 8px;
}
.brand-desc {
	font-size: 11px;
	color: #888;
	line-height: 1.5;
	margin: 0;
}

/* ============================================================
   KVKK / ÇEREZ BANNER
   ============================================================ */
.kvkk-banner {
	position: fixed;
	bottom: -100%;
	left: 0;
	right: 0;
	z-index: 9999;
	background: #1a1a1a;
	color: #fff;
	padding: 0;
	transition: bottom .4s cubic-bezier(.4,0,.2,1);
	box-shadow: 0 -4px 24px rgba(0,0,0,.3);
}
.kvkk-banner.visible {
	bottom: 0;
}
.kvkk-inner {
	display: flex;
	align-items: center;
	gap: 32px;
	max-width: 1280px;
	margin: 0 auto;
	padding: 18px 24px;
	flex-wrap: wrap;
}
.kvkk-text {
	flex: 1;
	min-width: 0;
}
.kvkk-text strong {
	font-size: 14px;
	display: block;
	margin-bottom: 4px;
}
.kvkk-text p {
	font-size: 13px;
	color: rgba(255,255,255,.75);
	line-height: 1.6;
	margin: 0;
}
.kvkk-text p a {
	color: var(--color-accent);
	text-decoration: underline;
}
.kvkk-actions {
	display: flex;
	gap: 10px;
	flex-shrink: 0;
}
.kvkk-btn {
	padding: 10px 22px;
	border-radius: var(--radius);
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	border: 2px solid transparent;
	transition: all var(--transition);
}
.kvkk-accept {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}
.kvkk-accept:hover { background: var(--color-primary-lt); border-color: var(--color-primary-lt); }
.kvkk-decline {
	background: transparent;
	color: rgba(255,255,255,.7);
	border-color: rgba(255,255,255,.3);
}
.kvkk-decline:hover { color: #fff; border-color: #fff; }

/* ============================================================
   FILTERS SIDEBAR (Shop)
   ============================================================ */
.shop-layout {
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: 28px;
	padding: 32px 0 56px;
}
.shop-sidebar { min-width: 0; }
.widget_layered_nav,
.widget_price_filter,
.widget_product_categories {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: 18px;
	margin-bottom: 20px;
}
.widget-title {
	font-size: 15px;
	font-weight: 700;
	margin-bottom: 14px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--color-primary);
}
.shop-main { min-width: 0; }

/* WooCommerce ordering */
.woocommerce-ordering select {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: 8px 12px;
	font-size: 14px;
	outline: none;
}
.woocommerce-result-count { color: var(--color-text-light); font-size: 14px; }

/* ============================================================
   SINGLE PRODUCT PAGE
   ============================================================ */
.single-product-page {
	padding: 32px 20px 72px;
}

/* Breadcrumb */
.single-product-page .woocommerce-breadcrumb {
	font-size: 13px;
	color: var(--color-text-light);
	margin-bottom: 28px;
	display: block;
}
.single-product-page .woocommerce-breadcrumb a {
	color: var(--color-primary);
}
.single-product-page .woocommerce-breadcrumb a:hover {
	text-decoration: underline;
}

/* Ana ürün grid: görsel | özet */
.single-product-page .product.type-product {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto;
	gap: 48px;
	align-items: start;
}

/* Görsel alanı */
.single-product-page div.woocommerce-product-gallery {
	grid-column: 1;
	border: 1px solid var(--color-border);
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
}
.single-product-page .woocommerce-product-gallery__image img {
	width: 100% !important;
	height: auto !important;
	object-fit: contain;
	padding: 24px;
	background: #fff;
}
.single-product-page .flex-control-thumbs {
	display: flex;
	gap: 8px;
	padding: 12px;
	border-top: 1px solid var(--color-border);
	list-style: none;
	margin: 0;
}
.single-product-page .flex-control-thumbs li { flex: 0 0 72px; }
.single-product-page .flex-control-thumbs li img {
	border: 2px solid transparent;
	border-radius: 8px;
	cursor: pointer;
	padding: 4px;
	transition: border-color var(--transition);
}
.single-product-page .flex-control-thumbs li img.flex-active,
.single-product-page .flex-control-thumbs li img:hover {
	border-color: var(--color-primary);
}

/* Sale badge */
.single-product-page span.onsale {
	background: #e53935 !important;
	color: #fff !important;
	border-radius: 6px !important;
	padding: 4px 12px !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	top: 12px !important;
	left: 12px !important;
}

/* Özet alanı */
.single-product-page div.summary.entry-summary {
	grid-column: 2;
}

/* Başlık */
.single-product-page .product_title {
	font-size: 26px !important;
	font-weight: 800 !important;
	line-height: 1.3 !important;
	color: var(--color-text) !important;
	margin-bottom: 12px !important;
}

/* Rating */
.single-product-page .woocommerce-product-rating {
	margin-bottom: 16px;
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	color: var(--color-text-light);
}
.single-product-page .star-rating { color: #f59e0b; font-size: 14px; }

/* Fiyat */
.single-product-page p.price,
.single-product-page span.price {
	font-size: 30px !important;
	font-weight: 800 !important;
	color: var(--color-primary) !important;
	margin-bottom: 20px !important;
	display: block !important;
}
.single-product-page p.price del,
.single-product-page span.price del {
	color: #bbb !important;
	font-size: 18px !important;
	font-weight: 400 !important;
	margin-right: 8px !important;
}

/* Kısa açıklama */
.single-product-page .woocommerce-product-details__short-description {
	font-size: 14px;
	color: #555;
	line-height: 1.8;
	margin-bottom: 24px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--color-border);
}

/* Sepete ekle formu */
.single-product-page form.cart {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 24px;
	flex-wrap: wrap;
}
.single-product-page form.cart .qty {
	width: 72px;
	padding: 12px 10px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-size: 16px;
	text-align: center;
	font-weight: 600;
}
.single-product-page form.cart .single_add_to_cart_button {
	flex: 1;
	background: var(--color-primary) !important;
	color: #fff !important;
	border: none !important;
	padding: 13px 28px !important;
	border-radius: var(--radius) !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: background var(--transition) !important;
	letter-spacing: .3px;
	text-transform: none !important;
}
.single-product-page form.cart .single_add_to_cart_button:hover {
	background: var(--color-primary-dk) !important;
}

/* Ürün meta (SKU, kategori) */
.single-product-page .product_meta {
	font-size: 13px;
	color: var(--color-text-light);
	margin-top: 20px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding-top: 20px;
	border-top: 1px solid var(--color-border);
}
.single-product-page .product_meta a {
	color: var(--color-primary);
}
.single-product-page .product_meta span.label {
	font-weight: 600;
	color: #555;
}

/* WhatsApp ile teklif butonu */
.single-product-page .defne-whatsapp-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: #25d366;
	color: #fff;
	padding: 12px 20px;
	border-radius: var(--radius);
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	margin-top: 12px;
	transition: background var(--transition);
}
.single-product-page .defne-whatsapp-btn:hover { background: #1da851; color:#fff; }
.single-product-page .defne-whatsapp-btn svg { width:20px; height:20px; }

/* ---- Sekmeler (Description / Reviews) ---- */
.single-product-page .woocommerce-tabs {
	grid-column: 1 / -1;
	margin-top: 40px;
}

/* Tab başlık çubuğu — alt çizgi stili */
.single-product-page .woocommerce-tabs ul.tabs {
	display: flex;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
	border-bottom: 2px solid var(--color-border);
}
.single-product-page .woocommerce-tabs ul.tabs::before,
.single-product-page .woocommerce-tabs ul.tabs::after { display: none !important; }

.single-product-page .woocommerce-tabs ul.tabs li {
	margin: 0;
	position: relative;
}
.single-product-page .woocommerce-tabs ul.tabs li::before,
.single-product-page .woocommerce-tabs ul.tabs li::after { display: none !important; }

.single-product-page .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: 14px 28px;
	font-size: 14px;
	font-weight: 600;
	color: #888;
	background: transparent;
	border: none;
	border-radius: 0;
	position: relative;
	transition: color var(--transition);
	text-decoration: none;
}
.single-product-page .woocommerce-tabs ul.tabs li a::after {
	content: '';
	display: block !important;
	position: absolute;
	bottom: -2px;
	left: 0;
	right: 0;
	height: 3px;
	background: transparent;
	border-radius: 3px 3px 0 0;
	transition: background var(--transition);
}
.single-product-page .woocommerce-tabs ul.tabs li.active a {
	color: var(--color-primary);
	background: transparent;
	border: none;
	margin-bottom: 0;
}
.single-product-page .woocommerce-tabs ul.tabs li.active a::after {
	background: var(--color-primary);
}
.single-product-page .woocommerce-tabs ul.tabs li a:hover {
	color: var(--color-primary);
}

/* Panel içeriği */
.single-product-page .woocommerce-tabs .wc-tab,
.single-product-page .woocommerce-tabs .panel {
	padding: 28px 0;
	font-size: 14px;
	line-height: 1.9;
	color: #444;
}
.single-product-page .woocommerce-tabs .panel h2,
.single-product-page .woocommerce-tabs .wc-tab h2 {
	display: none;
}

/* Özellikler tablosu */
.single-product-page .woocommerce-tabs .panel table,
.single-product-page .woocommerce-tabs .wc-tab table {
	width: 100%;
	max-width: 600px;
	border-collapse: collapse;
	font-size: 14px;
}
.single-product-page .woocommerce-tabs .panel table th,
.single-product-page .woocommerce-tabs .panel table td,
.single-product-page .woocommerce-tabs .wc-tab table th,
.single-product-page .woocommerce-tabs .wc-tab table td {
	padding: 11px 16px;
	border: 1px solid var(--color-border);
	text-align: left;
	vertical-align: top;
}
.single-product-page .woocommerce-tabs .panel table th,
.single-product-page .woocommerce-tabs .wc-tab table th {
	background: #f7f9f7;
	font-weight: 600;
	color: #444;
	width: 180px;
}
.single-product-page .woocommerce-tabs .panel table tr:nth-child(even) td,
.single-product-page .woocommerce-tabs .wc-tab table tr:nth-child(even) td {
	background: #fafafa;
}

/* İlgili Ürünler */
.single-product-page .related.products,
.single-product-page .up-sells.upsells.products {
	grid-column: 1 / -1;
	margin-top: 48px;
}
.single-product-page .related.products h2,
.single-product-page .up-sells h2 {
	font-size: 22px;
	font-weight: 800;
	color: var(--color-text);
	margin-bottom: 24px;
	padding-bottom: 10px;
	border-bottom: 3px solid var(--color-primary);
	display: inline-block;
}

/* Responsive */
@media (max-width: 860px) {
	.single-product-page .product.type-product {
		grid-template-columns: 1fr;
	}
	.single-product-page div.woocommerce-product-gallery {
		grid-column: 1;
		position: static !important;
	}
	.single-product-page div.summary.entry-summary {
		grid-column: 1;
	}
	.single-product-page .woocommerce-tabs {
		grid-column: 1;
	}
	.single-product-page .related.products,
	.single-product-page .up-sells {
		grid-column: 1;
	}
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.breadcrumb-wrap {
	background: var(--color-bg);
	padding: 10px 0;
	font-size: 13px;
	color: var(--color-text-light);
}
.breadcrumb-wrap a { color: var(--color-primary); }
.breadcrumb-wrap a:hover { text-decoration: underline; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
	background: #111;
	color: rgba(255,255,255,.8);
	padding: 48px 0 24px;
}
.footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 32px;
	margin-bottom: 36px;
}
.footer-col h4 {
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	margin-bottom: 16px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--color-primary);
}
.footer-col p, .footer-col li { font-size: 14px; line-height: 1.8; }
.footer-col a { color: rgba(255,255,255,.7); transition: color var(--transition); }
.footer-col a:hover { color: #fff; }
.footer-col .contact-item {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 10px;
	font-size: 14px;
}
.footer-col svg { width: 16px; height: 16px; flex-shrink: 0; fill: var(--color-accent); }
.footer-bottom {
	border-top: 1px solid rgba(255,255,255,.1);
	padding-top: 20px;
	text-align: center;
	font-size: 13px;
	color: rgba(255,255,255,.45);
}

/* ============================================================
   WHATSAPP BUTTON
   ============================================================ */
.whatsapp-float {
	position: fixed;
	bottom: 30px;
	right: 30px;
	z-index: 9999;
	width: 58px;
	height: 58px;
	background: #25d366;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 16px rgba(37,211,102,.45);
	transition: transform .25s, box-shadow .25s;
}
.whatsapp-float:hover {
	transform: scale(1.1);
	box-shadow: 0 6px 24px rgba(37,211,102,.6);
}
.whatsapp-float svg { width: 32px; height: 32px; fill: #fff; }
.whatsapp-float::before {
	content: "WhatsApp ile yazın";
	position: absolute;
	right: 68px;
	background: #222;
	color: #fff;
	font-size: 12px;
	padding: 6px 10px;
	border-radius: 6px;
	white-space: nowrap;
	opacity: 0;
	pointer-events: none;
	transition: opacity .2s;
}
.whatsapp-float:hover::before { opacity: 1; }

/* ============================================================
   UTILITIES
   ============================================================ */
.btn {
	display: inline-block;
	padding: 10px 24px;
	border-radius: var(--radius);
	font-weight: 600;
	font-size: 14px;
	cursor: pointer;
	transition: all var(--transition);
	border: none;
}
.btn-primary { background: var(--color-primary); color: #fff; }
.btn-primary:hover { background: var(--color-primary-dk); }
.btn-outline { background: transparent; color: var(--color-primary); border: 2px solid var(--color-primary); }
.btn-outline:hover { background: var(--color-primary); color: #fff; }

.text-center { text-align: center; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mb-2 { margin-bottom: 16px; }
.py-3 { padding-top: 24px; padding-bottom: 24px; }

/* ============================================================
   WOOCOMMERCE OVERRIDES
   ============================================================ */
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-info {
	border-radius: var(--radius);
	padding: 14px 18px;
	margin-bottom: 16px;
	font-size: 14px;
}
.woocommerce-message { background: #e8f5e9; border-left: 4px solid var(--color-primary); }
.woocommerce-error   { background: #ffebee; border-left: 4px solid #e53935; list-style: none; }
.woocommerce-info    { background: #e3f2fd; border-left: 4px solid #1976d2; }

.woocommerce nav.woocommerce-pagination ul {
	display: flex; gap: 6px; justify-content: center; margin: 32px 0; padding: 0;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius) !important;
	padding: 8px 14px !important;
	font-size: 14px !important;
	color: var(--color-text) !important;
	background: #fff !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--color-primary) !important;
	color: #fff !important;
	border-color: var(--color-primary) !important;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
	display: inline-block;
	padding: 11px 28px;
	border-radius: var(--radius);
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: var(--transition);
	border: 2px solid transparent;
	text-align: center;
}
.btn-primary {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}
.btn-primary:hover {
	background: var(--color-primary-dk);
	border-color: var(--color-primary-dk);
}
.btn-outline {
	background: transparent;
	color: var(--color-primary);
	border-color: var(--color-primary);
}
.btn-outline:hover {
	background: var(--color-primary);
	color: #fff;
}

/* ============================================================
   POSTS GRID (index.php)
   ============================================================ */
.posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	margin-top: 24px;
}
.post-card {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	overflow: hidden;
	background: #fff;
	transition: var(--transition);
}
.post-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.post-card .post-thumb img { width: 100%; height: 200px; object-fit: cover; }
.post-card .post-body { padding: 20px; }
.post-card h2 { font-size: 18px; margin-bottom: 8px; }
.post-card h2 a:hover { color: var(--color-primary); }
.post-meta { font-size: 13px; color: var(--color-text-light); margin-bottom: 10px; }
.post-excerpt { font-size: 14px; color: #555; margin-bottom: 16px; line-height: 1.7; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
	.category-grid { grid-template-columns: repeat(4, 1fr); }
	ul.products, .products-grid { grid-template-columns: repeat(3, 1fr) !important; }
	.footer-grid { grid-template-columns: 1fr 1fr; }
	.brands-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
	/* Header */
	.header-main { flex-wrap: wrap; gap: 12px; padding: 12px 0; }
	.header-left { gap: 14px; flex-wrap: wrap; }
	.header-contact { display: none; }
	.site-logo img, .site-logo a img { height: 52px !important; }
	.header-search { max-width: 100%; order: 3; flex: 1 1 100%; }

	/* Mobil menü */
	.mobile-menu-toggle { display: flex; }
	.nav-menu {
		display: block;
		position: fixed;
		top: 0;
		left: -280px;
		width: 280px;
		height: 100vh;
		background: var(--color-primary-dk);
		z-index: 1000;
		padding: 72px 0 24px;
		overflow-y: auto;
		transition: left .3s cubic-bezier(.4,0,.2,1);
		flex-direction: column;
	}
	.nav-menu.open { left: 0; }
	.nav-menu li { border-bottom: 1px solid rgba(255,255,255,.08); }
	.nav-menu a { padding: 14px 24px; font-size: 15px; display: block; }
	.nav-menu .sub-menu {
		position: static;
		display: none;
		box-shadow: none;
		background: rgba(0,0,0,.2);
		border-radius: 0;
		min-width: 0;
	}
	.nav-menu li.focus > .sub-menu,
	.nav-menu li:focus-within > .sub-menu { display: block; }
	.nav-menu .sub-menu a { padding: 10px 24px 10px 40px; color: rgba(255,255,255,.8); border: none; }

	/* Slider */
	.hero-slide { flex-direction: column; height: auto; }
	.hero-text { flex: none; width: 100%; padding: 32px 20px 16px; }
	.hero-text h1 { font-size: 22px; }
	.hero-text p  { font-size: 14px; margin-bottom: 16px; max-width: 100%; }
	.hero-collage { flex: none; width: 100%; padding: 0 16px 20px; gap: 8px; }
	.hero-collage-item { min-height: 100px; }
	.slider-arrow { width: 34px; height: 34px; font-size: 13px; top: 25%; }
	.slider-prev { left: 6px; }
	.slider-next { right: 6px; }

	/* Markalar */
	.brands-grid { grid-template-columns: repeat(2, 1fr); }

	/* KVKK */
	.kvkk-inner { flex-direction: column; gap: 16px; padding: 16px; }
	.kvkk-actions { width: 100%; justify-content: stretch; }
	.kvkk-btn { flex: 1; text-align: center; }
	.category-grid { grid-template-columns: repeat(3, 1fr); }
	ul.products, .products-grid { grid-template-columns: repeat(2, 1fr) !important; }
	.shop-layout { grid-template-columns: 1fr; }
	.shop-sidebar { display: none; }
	.single-product-layout { grid-template-columns: 1fr; gap: 24px; }
	.nav-menu { display: none; flex-direction: column; }
	.nav-menu.open { display: flex; }
	.mobile-menu-toggle { display: block; }
	.footer-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
	.hero h1 { font-size: 26px; }
	.whatsapp-float { bottom: 20px; right: 16px; width: 50px; height: 50px; }
	.whatsapp-float::before { display: none; }
	.posts-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 480px) {
	.category-grid { grid-template-columns: repeat(2, 1fr); }
	ul.products, .products-grid { grid-template-columns: repeat(2, 1fr) !important; }
	.footer-grid { grid-template-columns: 1fr; }
	.brands-grid { grid-template-columns: repeat(2, 1fr); }
}
