/*!
Theme Name:  Pozitif Kurumsal Developer Team
Theme URI:   https://pozitifkurumsal.com.tr
Description: Professional WooCommerce theme for Pozitif Kurumsal Developer Team. Modern, corporate and professional e-commerce solution for developer teams.
Author:      Pozitif Kurumsal Developer Team
Author URI:  https://pozitifkurumsal.com.tr
Version:     2.4.0
Requires at least: 6.7
Tested up to:      6.9
WC requires at least: 9.4
WC tested up to:      10.6
Requires PHP:   8.1
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  devcom
Tags: woocommerce, e-commerce, grid-layout, dark, one-column, two-columns, custom-menu, featured-images, full-width-template, theme-options

Pozitif Kurumsal Developer Team WordPress Theme, Copyright 2026 Pozitif Kurumsal
*/

/* ============================================================
   CHANGELOG
   ============================================================

   v2.3.0 — 2026-04-01
   ──────────────────────────────────────────────────────────
   BUG FIXES
   • Fatal Error giderildi: is_woocommerce(), is_cart(),
     is_checkout(), is_account_page() fonksiyonları WooCommerce
     yüklenmeden önce çağrılıyordu. Tüm WC hook bloğu
     add_action("woocommerce_init") içine alındı.
   • class-devcom-setup.php: is_woocommerce() ve is_shop()
     çağrıları function_exists() ile korundu.
   • header.php: fallback nav menüsündeki sözdizimi hatası
     ($fallback_cb ataması) düzeltildi.
   • WC()->cart null guard eklendi.

   UYUMLULUK
   • WordPress 6.9 tam uyumlu (Tested up to: 6.9)
   • WooCommerce 10.6 tam uyumlu (WC tested up to: 10.6)
   • PHP minimum 8.1 olarak güncellendi
   • theme.json v2 eklendi (WP 6.5+ block editor desteği)
   • WooCommerce HPOS (custom_order_tables) uyumluluğu
   • WooCommerce Blocks (cart_checkout_blocks) uyumluluğu
   • WP 6.8 Speculative Loading desteği (conservative prefetch)
   • LCP hero görseli fetchpriority="high" optimizasyonu
   • Google Fonts preconnect resource hints eklendi
   • WordPress preset CSS değişkenleri tema tokenlarına bağlandı

   ──────────────────────────────────────────────────────────
   v2.2.0 — 2026-04-01
   ──────────────────────────────────────────────────────────
   UYUMLULUK
   • WordPress 6.7+ minimum gereksinim
   • WooCommerce 9.4+ minimum gereksinim
   • PHP 8.1+ minimum gereksinim
   • theme.json dosyası eklendi (WP 6.6 schema, v2)
   • add_theme_support("border"), "link-color", "appearance-tools"
   • add_editor_style() ile Gutenberg editor desteği

   ──────────────────────────────────────────────────────────
   v2.1.1 — 2026-04-01
   ──────────────────────────────────────────────────────────
   BUG FIXES
   • functions.php DEVCOM_VERSION "1.2.0" → "2.1.1" düzeltildi
   • archive-product.php "ShopMax" referansları temizlendi
   • my-account.php smx- prefix → devcom- prefix
   • wp_ajax_shopmax_make_zip → wp_ajax_devcom_make_zip

   EKLEMELER
   • page-templates/contact.php: Profesyonel iletişim sayfası
     (form, telefon, adres, harita, çalışma saatleri)
   • İletişim formu handler (devcom_handle_contact_form)
   • Contact page CSS (~350 satır)
   • Ana sayfada "Add" butonu → "Sepete Ekle" düzeltildi
   • JS localization stringleri Türkçeye çevrildi
   • inc/admin/ klasörü kaldırıldı (ayrı eklentiye taşındı)

   ──────────────────────────────────────────────────────────
   v2.1.0 — 2026-03-31
   ──────────────────────────────────────────────────────────
   EKLEMELER
   • Modern kurumsal e-ticaret estetiği ile tam yeniden tasarım
   • WooCommerce AJAX sepet desteği
   • Öne çıkan ürünler, kategori grid, bülten bölümleri
   • SVG logo yükleme desteği
   • Customizer paneli (renkler, tipografi, hero ayarları)
   • DevCom Nav Walker (dropdown menü desteği)
   • 5 widget alanı (shop sidebar, 4 footer kolonu)
   • Türkçe tam dil desteği

   ============================================================ */


/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  /* Brand */
  --clr-accent:        #0078d4;
  --clr-accent-hover:  #005fa3;
  --clr-accent-light:  #50a3e0;
  --clr-accent-glow:   rgba(0,120,212,.18);

  /* Surface */
  --clr-bg:            #ffffff;
  --clr-bg-alt:        #f5f5f5;
  --clr-bg-dark:       #0f0f0f;
  --clr-bg-card:       #ffffff;
  --clr-bg-overlay:    rgba(15,15,15,.88);

  /* Text */
  --clr-text:          #1a1a1a;
  --clr-text-muted:    #6e6e6e;
  --clr-text-light:    #ffffff;
  --clr-text-heading:  #050505;

  /* Borders */
  --clr-border:        #e0e0e0;
  --clr-border-dark:   #2a2a2a;

  /* Status */
  --clr-success:       #107c10;
  --clr-warning:       #d83b01;
  --clr-info:          #0078d4;

  /* Typography */
  --font-display:      Arial, 'Helvetica Neue', Helvetica, sans-serif;
  --font-body:         Arial, 'Helvetica Neue', Helvetica, sans-serif;
  --font-mono:         'Courier New', Courier, monospace;

  --fs-xs:   .75rem;
  --fs-sm:   .875rem;
  --fs-base: 1rem;
  --fs-md:   1.125rem;
  --fs-lg:   1.375rem;
  --fs-xl:   1.75rem;
  --fs-2xl:  2.25rem;
  --fs-3xl:  3rem;
  --fs-4xl:  4rem;

  --fw-regular: 400;
  --fw-medium:  500;
  --fw-semibold:600;
  --fw-bold:    700;
  --fw-black:   900;

  /* Spacing */
  --sp-1: .25rem; --sp-2: .5rem; --sp-3: .75rem; --sp-4: 1rem;
  --sp-5: 1.25rem; --sp-6: 1.5rem; --sp-8: 2rem; --sp-10: 2.5rem;
  --sp-12: 3rem; --sp-16: 4rem; --sp-20: 5rem; --sp-24: 6rem;

  /* Layout */
  --container: 1280px;

  /* ── WordPress / theme.json preset bridge ──────── */
  /* Maps WP block editor preset vars to DevCom tokens */
  --wp--preset--color--accent:       var(--clr-accent);
  --wp--preset--color--accent-dark:  var(--clr-accent-hover);
  --wp--preset--color--accent-light: var(--clr-accent-light);
  --wp--preset--color--foreground:   var(--clr-text);
  --wp--preset--color--background:   var(--clr-bg);
  --wp--preset--color--dark:         var(--clr-bg-dark);
  --wp--preset--color--muted:        var(--clr-text-muted);
  --wp--preset--color--success:      var(--clr-success);
  --wp--preset--color--warning:      var(--clr-warning);
  --container-wide: 1440px;
  --gutter: clamp(1rem, 4vw, 2rem);

  /* Effects */
  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  16px;
  --radius-xl:  24px;
  --radius-full: 9999px;

  --shadow-sm:  0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.08);
  --shadow-md:  0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:  0 16px 48px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.08);
  --shadow-accent: 0 8px 32px rgba(0,120,212,.22);

  --transition: 220ms cubic-bezier(.4,0,.2,1);
  --transition-slow: 400ms cubic-bezier(.4,0,.2,1);
}

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

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: var(--fw-regular);
  line-height: 1.65;
  color: var(--clr-text);
  background: var(--clr-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video { max-width: 100%; height: auto; display: block; }
a { color: var(--clr-accent); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--clr-accent-hover); }

ul, ol { list-style: none; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  color: var(--clr-text-heading);
  line-height: 1.15;
  letter-spacing: -.02em;
}
h1 { font-size: clamp(var(--fs-2xl), 5vw, var(--fs-4xl)); font-weight: var(--fw-black); }
h2 { font-size: clamp(var(--fs-xl), 3vw, var(--fs-3xl)); }
h3 { font-size: clamp(var(--fs-lg), 2.5vw, var(--fs-2xl)); }
h4 { font-size: var(--fs-xl); font-weight: var(--fw-semibold); }
h5 { font-size: var(--fs-lg); font-weight: var(--fw-semibold); }
h6 { font-size: var(--fs-md); font-weight: var(--fw-medium); }

p { margin-bottom: var(--sp-4); }
p:last-child { margin-bottom: 0; }

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container--wide { max-width: var(--container-wide); }
.container--narrow { max-width: 800px; }

.grid { display: grid; gap: var(--sp-6); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.flex { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }

.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: .75rem 1.5rem;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: .02em;
  text-transform: none;
  border: 2px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
  text-decoration: none;
}
.btn--primary {
  background: var(--clr-accent);
  color: #fff;
  border-color: var(--clr-accent);
}
.btn--primary:hover {
  background: var(--clr-accent-hover);
  border-color: var(--clr-accent-hover);
  color: #fff;
  box-shadow: var(--shadow-accent);
  transform: translateY(-1px);
}
.btn--outline {
  background: transparent;
  color: var(--clr-accent);
  border-color: var(--clr-accent);
}
.btn--outline:hover {
  background: var(--clr-accent);
  color: #fff;
}
.btn--dark {
  background: var(--clr-bg-dark);
  color: #fff;
  border-color: var(--clr-bg-dark);
}
.btn--dark:hover {
  background: #1f1f1f;
  box-shadow: var(--shadow-lg);
  transform: translateY(-1px);
}
.btn--ghost {
  background: transparent;
  color: var(--clr-text);
  border-color: var(--clr-border);
}
.btn--ghost:hover { background: var(--clr-bg-alt); }
.btn--sm { padding: .5rem 1rem; font-size: var(--fs-xs); }
.btn--lg { padding: 1rem 2rem; font-size: var(--fs-md); }
.btn--block { width: 100%; justify-content: center; }

/* ============================================================
   BADGE / LABEL
   ============================================================ */
.badge {
  display: inline-block;
  padding: .2em .65em;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  background: var(--clr-accent-glow);
  color: var(--clr-accent);
}
.badge--dark { background: var(--clr-bg-dark); color: #fff; }
.badge--success { background: rgba(16,124,16,.12); color: var(--clr-success); }
.badge--sale { background: var(--clr-warning); color: #fff; }

/* ============================================================
   SITE HEADER
   ============================================================ */
/* Header CSS → assets/css/woocommerce.css dosyasında yönetiliyor */


/* header-icon-btn:hover → woocommerce.css */

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero {
  position: relative;
  background: var(--clr-bg-dark);
  color: #fff;
  padding: clamp(var(--sp-16), 12vw, var(--sp-24)) 0;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 70% 50%, rgba(0,120,212,.35) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(80,163,224,.12) 0%, transparent 60%);
  pointer-events: none;
}
.hero__grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.hero__content {
  position: relative;
  z-index: 2;
  max-width: 680px;
}
.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: .4rem 1rem;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--clr-accent-light);
  border: 1px solid rgba(80,163,224,.3);
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-6);
}
.hero h1 { color: #fff; margin-bottom: var(--sp-6); }
.hero h1 span { color: var(--clr-accent-light); }
.hero__desc {
  font-size: var(--fs-md);
  color: rgba(255,255,255,.7);
  margin-bottom: var(--sp-8);
  max-width: 540px;
}
.hero__actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; }

.hero__media {
  position: absolute;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  width: 45%;
  max-width: 600px;
  z-index: 1;
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
/* ============================================================
   SECTION HEADER — kompakt, güçlü
   ============================================================ */
.section-header {
  margin-bottom: 28px;
}
.section-header.flex-between {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

/* Eyebrow — küçük etiket */
.section-header__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--clr-accent, #0078d4);
  margin-bottom: 6px;
}
.section-header__eyebrow::before {
  content: '';
  display: block;
  width: 16px;
  height: 2px;
  background: var(--clr-accent, #0078d4);
  border-radius: 2px;
  flex-shrink: 0;
}

/* H2 başlık — global h2'den bağımsız, kontrollü */
.section-header h2 {
  font-size: 1.65rem;
  font-weight: 800;
  color: #0a0f1e;
  line-height: 1.18;
  margin: 0;
  letter-spacing: -.02em;
}

/* Alt açıklama metni */
.section-header p {
  color: #6b7280;
  font-size: .9rem;
  max-width: 520px;
  margin: 8px 0 0;
  line-height: 1.6;
}

/* Ortalanmış varyant */
.section-header--center {
  text-align: center;
}
.section-header--center .section-header__eyebrow {
  margin-inline: auto;
}
.section-header--center h2 {
  margin-inline: auto;
}
.section-header--center p {
  margin-inline: auto;
}

/* Koyu arka plan varyantı */
.section--dark .section-header h2 { color: #fff; }
.section--dark .section-header p   { color: rgba(255,255,255,.6); }
.section--dark .section-header__eyebrow { color: var(--clr-accent-light, #50a3e0); }
.section--dark .section-header__eyebrow::before { background: var(--clr-accent-light, #50a3e0); }

/* ============================================================
   SECTION SPACING — daha kompakt
   ============================================================ */
.section { padding: 52px 0; }
.section--alt { background: #f8fafc; }
.section--dark { background: #0a0f1e; color: #fff; }
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4 { color: #fff; }
.section--dark p,.section--dark li { color: rgba(255,255,255,.7); }

/* ============================================================
   PRODUCT CARDS
   ============================================================ */
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

/* ════════════════════════════════════════
   ÜRÜN KARTI — Profesyonel v2.4
   ════════════════════════════════════════ */
.product-card {
  position: relative;
  background: #fff;
  border: 1px solid #e8edf2;
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .22s, box-shadow .22s, transform .22s;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.product-card:hover {
  border-color: var(--clr-accent, #0078d4);
  box-shadow: 0 12px 36px rgba(0,120,212,.14);
  transform: translateY(-4px);
}

/* ── Görsel alanı ── */
.product-card__image {
  position: relative;
  height: 220px;
  overflow: hidden;
  background: #f4f6f9;
  flex-shrink: 0;
}
.product-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .45s cubic-bezier(.25,.46,.45,.94);
}
.product-card:hover .product-card__image img { transform: scale(1.06); }

/* ── Badge sistemi — sol üst köşe ── */
.product-card__badges {
  position: absolute;
  top: 10px;
  left: 10px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  z-index: 3;
}

/* Temel badge */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .62rem;
  font-weight: 800;
  padding: 3px 9px;
  border-radius: 5px;
  text-transform: uppercase;
  letter-spacing: .06em;
  line-height: 1.4;
  white-space: nowrap;
  box-shadow: 0 2px 6px rgba(0,0,0,.18);
}

/* İndirim — kırmızı + yüzde gösterir */
.badge--sale {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  color: #fff;
}
/* Yeni ürün — yeşil */
.badge--new {
  background: linear-gradient(135deg, #10b981, #059669);
  color: #fff;
}
/* Öne Çıkan — turuncu */
.badge--featured {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #fff;
}
/* En Çok Satan — mor */
.badge--bestseller {
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
  color: #fff;
}
/* Sınırlı Stok — koyu */
.badge--limited {
  background: linear-gradient(135deg, #374151, #1f2937);
  color: #fff;
}
/* Yakında */
.badge--coming {
  background: linear-gradient(135deg, #6366f1, #4f46e5);
  color: #fff;
}
/* Tükendi */
.badge--outofstock {
  background: #f1f5f9;
  color: #64748b;
  box-shadow: none;
}
/* Ücretsiz Kargo */
.badge--freeship {
  background: linear-gradient(135deg, #0ea5e9, #0284c7);
  color: #fff;
}

/* ── Görsel üst sağ: favori butonu ── */
.product-card__wishlist {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(6px);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #9ca3af;
  font-size: 1rem;
  text-decoration: none;
  transition: background .18s, color .18s, transform .18s;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
  z-index: 3;
  opacity: 0;
  transform: scale(.8);
}
.product-card:hover .product-card__wishlist {
  opacity: 1;
  transform: scale(1);
}
.product-card__wishlist:hover {
  background: #ef4444;
  color: #fff;
}

/* ── Hızlı görüntüle — alt ortada ── */
.product-card__quickview {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 10px;
  background: rgba(10,15,30,.85);
  backdrop-filter: blur(6px);
  color: #fff;
  font-size: .75rem;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  letter-spacing: .04em;
  transform: translateY(100%);
  transition: transform .25s cubic-bezier(.25,.46,.45,.94);
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.product-card:hover .product-card__quickview { transform: translateY(0); }
.product-card__quickview svg { width: 13px; height: 13px; }

/* ── İndirim yüzdesi — sağ alt görsel köşesi ── */
.product-card__discount-pill {
  position: absolute;
  bottom: 48px;
  right: 10px;
  background: #ef4444;
  color: #fff;
  font-size: .7rem;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 20px;
  z-index: 3;
  opacity: 0;
  transition: opacity .2s;
}
.product-card:hover .product-card__discount-pill { opacity: 1; }

/* ── Kart gövdesi ── */
.product-card__body {
  padding: 14px 14px 14px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 0;
}

.product-card__cat {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--clr-accent, #0078d4);
  margin-bottom: 5px;
  opacity: .85;
}
.product-card__cat a { color: inherit; text-decoration: none; }

.product-card__title {
  font-size: .92rem;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.4;
  margin: 0 0 7px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
}
.product-card__title a { color: inherit; text-decoration: none; }
.product-card__title a:hover { color: var(--clr-accent, #0078d4); }

/* Rating */
.product-card__rating {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 10px;
}
.stars {
  color: #f59e0b;
  font-size: .78rem;
  letter-spacing: 1px;
  line-height: 1;
}
.rating-count { font-size: .7rem; color: #94a3b8; }

/* ── Footer: fiyat + sepet ── */
.product-card__footer {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid #f1f5f9;
}

.product-card__price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.price-old {
  font-size: .7rem;
  color: #94a3b8;
  text-decoration: line-through;
  line-height: 1.2;
}
.price-discount {
  font-size: .7rem;
  color: #16a34a;
  font-weight: 700;
}
.price-current {
  font-size: 1rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.2;
}
.price-save {
  font-size: .65rem;
  color: #ef4444;
  font-weight: 700;
}

/* Sepete Ekle — Hepsiburada tarzı: tam genişlik turuncu buton */
.add-to-cart-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  padding: 9px 12px;
  font-size: .8rem;
  font-weight: 700;
  background: #ff6000;
  color: #fff;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
  font-family: inherit;
  position: relative;
  overflow: hidden;
}
.add-to-cart-btn:hover { background: #e55500; }
.add-to-cart-btn .cart-icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.add-to-cart-btn .cart-icon-wrap svg { width: 16px; height: 16px; flex-shrink: 0; }

/* Eklendi durumu — yeşil */
.add-to-cart-btn.added { background: #16a34a; }
.add-to-cart-btn.added:hover { background: #15803d; }

/* Yazı kısmı */
.add-to-cart-btn .cart-label {
  font-size: .8rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
}

/* İkon değişimi */
.add-to-cart-btn .icon-cart  { display: block; }
.add-to-cart-btn .icon-check { display: none;  }
.add-to-cart-btn.added .icon-cart  { display: none;  }
.add-to-cart-btn.added .icon-check { display: block; }

/* Başarı mesajı balonu */
.add-to-cart-btn .cart-success {
  display: none;
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%; transform: translateX(-50%);
  background: #16a34a; color: #fff;
  font-size: 10px; font-weight: 600;
  padding: 4px 10px; border-radius: 6px;
  white-space: nowrap; pointer-events: none;
  animation: cartFadeUp .25s ease;
  z-index: 10;
}
@keyframes cartFadeUp {
  from { opacity: 0; transform: translateX(-50%) translateY(4px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.add-to-cart-btn.loading { opacity: .7; pointer-events: none; }
.add-to-cart-btn--disabled {
  opacity: .5; cursor: not-allowed;
}
.add-to-cart-btn--disabled:hover { background: #1e293b; }

/* Satış sayısı */
.sales-count {
  font-size: .65rem;
  color: #94a3b8;
  margin-left: 2px;
}
.sales-count::before { content: '·'; margin-right: 3px; }

/* Görsel placeholder */
.product-card__no-img {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f4f6f9;
}

/* Responsive — 3 kolon tablet */
@media (max-width: 1100px) {
  .product-grid { grid-template-columns: repeat(3, 1fr); }
}
/* 2 kolon mobil */
@media (max-width: 680px) {
  .product-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .product-card__image { height: 160px; }
  .product-card__body { padding: 10px; }
  .product-card__title { font-size: .82rem; }
  .add-to-cart-btn { padding: 7px 10px; font-size: .72rem; }
}

/* ============================================================
   PRODUCT FILTERS (SHOP PAGE)
   ============================================================ */
.shop-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--sp-8);
  align-items: start;
}

.filter-sidebar {
  position: sticky;
  top: 80px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
}
.filter-sidebar h3 {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--clr-text-heading);
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--clr-border);
}

.filter-group { margin-bottom: var(--sp-6); }
.filter-group__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-heading);
  margin-bottom: var(--sp-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
}

.filter-option {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) 0;
  cursor: pointer;
  transition: color var(--transition);
}
.filter-option:hover { color: var(--clr-accent); }
.filter-option input[type="checkbox"] { accent-color: var(--clr-accent); width: 15px; height: 15px; }
.filter-option label { font-size: var(--fs-sm); cursor: pointer; flex: 1; }
.filter-option .count { font-size: var(--fs-xs); color: var(--clr-text-muted); }

.price-range { padding: var(--sp-2) 0; }
.price-range input[type="range"] { width: 100%; accent-color: var(--clr-accent); }
.price-labels { display: flex; justify-content: space-between; font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: var(--sp-2); }

.color-swatches { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.color-swatch {
  width: 24px; height: 24px;
  border-radius: var(--radius-full);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition);
}
.color-swatch:hover, .color-swatch.active { border-color: var(--clr-accent); transform: scale(1.15); }

/* Shop Toolbar */
.shop-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-6);
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.shop-results { font-size: var(--fs-sm); color: var(--clr-text-muted); }
.shop-results strong { color: var(--clr-text-heading); }

.sort-select {
  padding: .5rem .75rem;
  font-size: var(--fs-sm);
  font-family: var(--font-body);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  background: var(--clr-bg);
  cursor: pointer;
  color: var(--clr-text);
}
.sort-select:focus { outline: none; border-color: var(--clr-accent); }

.view-toggle { display: flex; gap: var(--sp-1); }
.view-btn {
  width: 36px; height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  background: var(--clr-bg);
  cursor: pointer;
  color: var(--clr-text-muted);
  transition: all var(--transition);
}
.view-btn.active, .view-btn:hover { background: var(--clr-accent); color: #fff; border-color: var(--clr-accent); }

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
.single-product-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-12);
  align-items: start;
}

.product-gallery { position: sticky; top: 80px; }
.product-gallery__main {
  aspect-ratio: 1;
  background: var(--clr-bg-alt);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--sp-4);
  border: 1px solid var(--clr-border);
}
.product-gallery__main img { width: 100%; height: 100%; object-fit: cover; }
.product-gallery__thumbs { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--sp-3); }
.product-gallery__thumb {
  aspect-ratio: 1;
  background: var(--clr-bg-alt);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color var(--transition);
}
.product-gallery__thumb:hover, .product-gallery__thumb.active { border-color: var(--clr-accent); }
.product-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

.product-info {}
.product-info__cat {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--clr-accent);
  margin-bottom: var(--sp-3);
}
.product-info h1 { font-size: clamp(var(--fs-xl), 3vw, var(--fs-3xl)); margin-bottom: var(--sp-4); }
.product-info__rating { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-5); }
.review-link { font-size: var(--fs-xs); color: var(--clr-accent); }

.product-info__price {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--clr-border);
}
.product-info__price .price-current { font-size: var(--fs-3xl); }

.product-info__desc { margin-bottom: var(--sp-6); color: var(--clr-text-muted); }

.product-variations { margin-bottom: var(--sp-6); }
.variation-group { margin-bottom: var(--sp-4); }
.variation-label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-2);
  color: var(--clr-text-heading);
}
.variation-options { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.variation-option {
  padding: .4rem .9rem;
  font-size: var(--fs-sm);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition);
}
.variation-option:hover, .variation-option.active {
  background: var(--clr-accent);
  color: #fff;
  border-color: var(--clr-accent);
}

.add-to-cart-form {
  display: flex;
  gap: var(--sp-3);
  align-items: center;
  margin-bottom: var(--sp-5);
}
.qty-control {
  display: flex;
  align-items: center;
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.qty-btn {
  width: 40px; height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--clr-bg-alt);
  border: none;
  cursor: pointer;
  font-size: var(--fs-lg);
  color: var(--clr-text-muted);
  transition: all var(--transition);
}
.qty-btn:hover { background: var(--clr-accent); color: #fff; }
.qty-input {
  width: 52px; height: 48px;
  text-align: center;
  border: none;
  border-left: 1px solid var(--clr-border);
  border-right: 1px solid var(--clr-border);
  font-size: var(--fs-base);
  font-family: var(--font-body);
}
.qty-input:focus { outline: none; }

.product-meta { font-size: var(--fs-sm); color: var(--clr-text-muted); line-height: 2; }
.product-meta strong { color: var(--clr-text-heading); }

.product-tabs { margin-top: var(--sp-12); }
.tabs-nav {
  display: flex;
  border-bottom: 2px solid var(--clr-border);
  gap: var(--sp-2);
  margin-bottom: var(--sp-8);
}
.tab-btn {
  padding: var(--sp-3) var(--sp-5);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
  border: none;
  background: none;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--transition);
}
.tab-btn.active, .tab-btn:hover {
  color: var(--clr-accent);
  border-bottom-color: var(--clr-accent);
}

/* ============================================================
   CART PAGE
   ============================================================ */
.cart-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--sp-8);
  align-items: start;
}

.cart-table { width: 100%; border-collapse: collapse; }
.cart-table th {
  text-align: left;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 2px solid var(--clr-border);
}
.cart-table td {
  padding: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
  vertical-align: middle;
}

.cart-product {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}
.cart-product__img {
  width: 72px; height: 72px;
  border-radius: var(--radius-md);
  object-fit: cover;
  border: 1px solid var(--clr-border);
}
.cart-product__name { font-weight: var(--fw-semibold); color: var(--clr-text-heading); }
.cart-product__variant { font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: 2px; }

.remove-btn {
  color: var(--clr-text-muted);
  cursor: pointer;
  transition: color var(--transition);
  background: none;
  border: none;
  font-size: var(--fs-lg);
  line-height: 1;
  padding: var(--sp-1);
}
.remove-btn:hover { color: var(--clr-warning); }

.cart-summary {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  position: sticky;
  top: 80px;
}
.cart-summary h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
}
.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-2) 0;
  font-size: var(--fs-sm);
}
.summary-row--total {
  font-weight: var(--fw-bold);
  font-size: var(--fs-lg);
  padding-top: var(--sp-4);
  margin-top: var(--sp-3);
  border-top: 2px solid var(--clr-text-heading);
}

.coupon-form { display: flex; gap: var(--sp-2); margin: var(--sp-5) 0; }
.coupon-form input {
  flex: 1;
  padding: .6rem .9rem;
  font-size: var(--fs-sm);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
}
.coupon-form input:focus { outline: none; border-color: var(--clr-accent); }

/* ============================================================
   CHECKOUT
   ============================================================ */
.checkout-layout {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: var(--sp-10);
  align-items: start;
}

.checkout-section {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  margin-bottom: var(--sp-6);
}
.checkout-section h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-5);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.checkout-section h3 .step-num {
  width: 28px; height: 28px;
  background: var(--clr-accent);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.form-row { display: grid; gap: var(--sp-4); margin-bottom: var(--sp-4); }
.form-row--2col { grid-template-columns: 1fr 1fr; }
.form-row--3col { grid-template-columns: 1fr 1fr 1fr; }

.form-group { display: flex; flex-direction: column; gap: var(--sp-1); }
.form-group label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
}
.form-control {
  padding: .75rem 1rem;
  font-size: var(--fs-sm);
  font-family: var(--font-body);
  color: var(--clr-text);
  background: var(--clr-bg);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  transition: border-color var(--transition);
}
.form-control:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}

.payment-methods { display: flex; flex-direction: column; gap: var(--sp-3); }
.payment-option {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition);
}
.payment-option.active, .payment-option:hover { border-color: var(--clr-accent); background: var(--clr-accent-glow); }
.payment-option input[type="radio"] { accent-color: var(--clr-accent); }
.payment-option__icon { font-size: var(--fs-xl); }
.payment-option__label { font-weight: var(--fw-medium); }
.payment-option__desc { font-size: var(--fs-xs); color: var(--clr-text-muted); }

/* ============================================================
   MY ACCOUNT
   ============================================================ */
.account-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--sp-8);
  align-items: start;
}

.account-nav {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: sticky;
  top: 80px;
}
.account-nav__user {
  padding: var(--sp-6);
  border-bottom: 1px solid var(--clr-border);
  text-align: center;
}
.account-avatar {
  width: 64px; height: 64px;
  border-radius: var(--radius-full);
  background: var(--clr-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  color: #fff;
  margin: 0 auto var(--sp-3);
}
.account-nav__links a {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-5);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-muted);
  transition: all var(--transition);
  text-decoration: none;
}
.account-nav__links a:hover, .account-nav__links a.active {
  color: var(--clr-accent);
  background: var(--clr-accent-glow);
}

.account-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  margin-bottom: var(--sp-5);
}
.account-card h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.breadcrumbs {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-6);
}
.breadcrumbs a { color: var(--clr-text-muted); text-decoration: none; }
.breadcrumbs a:hover { color: var(--clr-accent); }
.breadcrumbs__sep { color: var(--clr-border); }
.breadcrumbs__current { color: var(--clr-text-heading); font-weight: var(--fw-medium); }

/* ============================================================
   CATEGORY CARDS
   ============================================================ */
.category-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--clr-bg-dark);
  aspect-ratio: 3/4;
  cursor: pointer;
}
.category-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .6;
  transition: all var(--transition-slow);
}
.category-card:hover img { opacity: .4; transform: scale(1.06); }
.category-card__info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--sp-6);
  background: linear-gradient(to top, rgba(0,0,0,.8) 0%, transparent 100%);
}
.category-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  color: #fff;
  margin-bottom: var(--sp-1);
}
.category-card__count { font-size: var(--fs-xs); color: rgba(255,255,255,.7); }
.category-card__link {
  position: absolute;
  inset: 0;
  z-index: 2;
}

/* ============================================================
   FEATURES SECTION
   ============================================================ */
.feature-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sp-4);
}
.feature-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-6);
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  transition: all var(--transition-slow);
}
.feature-card:hover { border-color: var(--clr-accent); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.feature-card__icon {
  width: 48px; height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--clr-accent-glow);
  border-radius: var(--radius-md);
  color: var(--clr-accent);
  font-size: var(--fs-xl);
}
.feature-card h4 { font-size: var(--fs-base); font-weight: var(--fw-semibold); }
.feature-card p { font-size: var(--fs-sm); color: var(--clr-text-muted); line-height: 1.5; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--sp-5); }
.testimonial-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  position: relative;
  transition: all var(--transition-slow);
}
.testimonial-card:hover { border-color: var(--clr-accent); box-shadow: var(--shadow-md); }
.testimonial-card::before {
  content: '"';
  font-family: var(--font-display);
  font-size: 80px;
  line-height: 1;
  color: var(--clr-accent-light);
  opacity: .3;
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-6);
}
.testimonial-card__stars { color: #f59e0b; margin-bottom: var(--sp-3); }
.testimonial-card__text {
  font-size: var(--fs-sm);
  line-height: 1.7;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-5);
}
.testimonial-card__author { display: flex; align-items: center; gap: var(--sp-3); }
.author-avatar {
  width: 40px; height: 40px;
  border-radius: var(--radius-full);
  background: var(--clr-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
}
.author-name { font-weight: var(--fw-semibold); font-size: var(--fs-sm); color: var(--clr-text-heading); }
.author-title { font-size: var(--fs-xs); color: var(--clr-text-muted); }

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter {
  background: var(--clr-bg-dark);
  border-radius: var(--radius-xl);
  padding: var(--sp-16) var(--sp-12);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.newsletter::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 50%, rgba(0,120,212,.25) 0%, transparent 70%);
  pointer-events: none;
}
.newsletter h2, .newsletter p { color: #fff; position: relative; }
.newsletter p { color: rgba(255,255,255,.7); }
.newsletter-form {
  display: flex;
  gap: var(--sp-3);
  max-width: 480px;
  margin: var(--sp-8) auto 0;
  position: relative;
}
.newsletter-form input {
  flex: 1;
  padding: .85rem 1.25rem;
  font-size: var(--fs-sm);
  font-family: var(--font-body);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--radius-sm);
  color: #fff;
}
.newsletter-form input::placeholder { color: rgba(255,255,255,.45); }
.newsletter-form input:focus { outline: none; border-color: var(--clr-accent-light); }

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer {
  background: var(--clr-bg-dark);
  color: rgba(255,255,255,.75);
}

/* ── Footer Top ── */
.footer-top { padding: var(--sp-16) 0 0; }

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--sp-10);
  padding-bottom: var(--sp-12);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

/* Marka kolonu */
.footer-brand {}
.footer-brand img,
.footer-brand .custom-logo { display: block; max-width: 160px; margin-bottom: var(--sp-4); }
.footer-brand p {
  font-size: var(--fs-sm);
  color: rgba(255,255,255,.55);
  line-height: 1.7;
  max-width: 260px;
  margin: 0 0 var(--sp-5);
}

/* Sosyal butonlar */
.footer-social {
  display: flex;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
}
.social-btn {
  width: 34px; height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 6px;
  color: rgba(255,255,255,.5);
  text-decoration: none;
  transition: background .18s, border-color .18s, color .18s;
  flex-shrink: 0;
}
.social-btn:hover { background: var(--clr-accent); border-color: var(--clr-accent); color: #fff; }

/* Link kolonları */
.footer-col {}
.footer-col h5 {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 var(--sp-5);
}
.footer-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.footer-col ul li { margin: 0; padding: 0; }
.footer-col a {
  font-size: var(--fs-sm);
  color: rgba(255,255,255,.55);
  text-decoration: none;
  transition: color .18s;
}
.footer-col a:hover { color: var(--clr-accent-light); }

/* İletişim listesi */
.footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  color: rgba(255,255,255,.55);
  font-size: var(--fs-sm);
}
.footer-contact-list svg { margin-top: 3px; flex-shrink: 0; color: var(--clr-accent-light); }
.footer-contact-list a { color: rgba(255,255,255,.55); text-decoration: none; }
.footer-contact-list a:hover { color: var(--clr-accent-light); }

/* ── Footer Bottom ── */
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); }
.footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-5) 0;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.footer-copy {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,.35);
  margin: 0;
}
.footer-bottom-links {
  display: flex;
  gap: var(--sp-5);
  flex-wrap: wrap;
}
.footer-bottom-links a {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,.35);
  text-decoration: none;
  transition: color .18s;
}
.footer-bottom-links a:hover { color: rgba(255,255,255,.7); }

/* ============================================================
   NOTIFICATIONS / WOOCOMMERCE NOTICES
   ============================================================ */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info,
.notice {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--radius-md);
  border-left: 4px solid;
  margin-bottom: var(--sp-5);
  font-size: var(--fs-sm);
}
.woocommerce-message { background: rgba(16,124,16,.07); border-color: var(--clr-success); color: var(--clr-success); }
.woocommerce-error { background: rgba(216,59,1,.07); border-color: var(--clr-warning); color: var(--clr-warning); }
.woocommerce-info { background: var(--clr-accent-glow); border-color: var(--clr-accent); color: var(--clr-accent); }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-1);
  margin-top: var(--sp-12);
}
.page-num {
  width: 40px; height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-muted);
  cursor: pointer;
  transition: all var(--transition);
  text-decoration: none;
}
.page-num:hover, .page-num.active {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: #fff;
}
.page-num--prev, .page-num--next { width: auto; padding: 0 var(--sp-4); }

/* ============================================================
   LOADING / SKELETON
   ============================================================ */
@keyframes skeleton-pulse {
  0%,100% { opacity: 1; }
  50% { opacity: .4; }
}
.skeleton {
  background: var(--clr-bg-alt);
  border-radius: var(--radius-sm);
  animation: skeleton-pulse 1.5s ease-in-out infinite;
}

/* ============================================================
   DARK MODE
   ============================================================ */
@media (prefers-color-scheme: dark) {
  :root {
    --clr-bg: #111113;
    --clr-bg-alt: #1a1a1c;
    --clr-bg-card: #1c1c1e;
    --clr-text: #e0e0e0;
    --clr-text-muted: #888;
    --clr-text-heading: #f5f5f5;
    --clr-border: #2c2c2e;
    --clr-accent-glow: rgba(0,120,212,.2);
  }
  /* site-header print → woocommerce.css */
  .product-card, .feature-card, .testimonial-card, .filter-sidebar,
  .cart-summary, .checkout-section, .account-nav, .account-card {
    background: var(--clr-bg-card);
  }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .shop-layout { grid-template-columns: 1fr; }
  .filter-sidebar { position: static; }
  .single-product-layout { grid-template-columns: 1fr; }
  .product-gallery { position: static; }
  .cart-layout { grid-template-columns: 1fr; }
  .checkout-layout { grid-template-columns: 1fr; }
  .account-layout { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .testimonials-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  /* nav responsive → woocommerce.css */
  .hero__media { display: none; }
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .form-row--2col, .form-row--3col { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .product-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-3); }
  .newsletter { padding: var(--sp-10) var(--sp-6); }
  .newsletter-form { flex-direction: column; }
  .hero__actions { flex-direction: column; }
}

/* ============================================================
   PRINT
   ============================================================ */
@media print {
  /* site-header print → woocommerce.css */
  .shop-layout, .cart-layout, .checkout-layout { display: block; }
}

/* ════════════════════════════════════════════════
   DEVELOPER TEAM SECTION
════════════════════════════════════════════════ */
.devcom-team-section {
  background: linear-gradient(180deg, #060c18 0%, #0a1628 100%);
  position: relative;
  overflow: hidden;
}
.devcom-team-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,120,212,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,120,212,.06) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
}

/* Section lead paragraph */
.devcom-team-lead {
  max-width: 720px;
  margin: 1rem auto 0;
  color: #94a3b8;
  font-size: 1.05rem;
  line-height: 1.75;
  text-align: center;
}

/* ── Values strip ─────────────────────────────── */
.devcom-team-values {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  margin: 3rem 0 4rem;
}
.devcom-value-card {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
  padding: 1.5rem;
  transition: border-color .2s, transform .2s;
}
.devcom-value-card:hover {
  border-color: rgba(0,120,212,.4);
  transform: translateY(-3px);
}
.devcom-value-card__icon {
  font-size: 1.75rem;
  margin-bottom: .75rem;
}
.devcom-value-card h4 {
  font-family: var(--font-display);
  font-size: .95rem;
  font-weight: 700;
  color: #f1f5f9;
  margin: 0 0 .6rem;
}
.devcom-value-card p {
  font-size: .825rem;
  color: #64748b;
  line-height: 1.65;
  margin: 0;
}

/* ── Team grid ─────────────────────────────────── */
.devcom-team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 3rem;
}
.devcom-team-card {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: border-color .2s, box-shadow .2s, transform .2s;
}
.devcom-team-card:hover {
  border-color: rgba(0,120,212,.35);
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  transform: translateY(-4px);
}

/* Avatar + name row */
.devcom-team-card__head {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.devcom-team-avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 2px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.devcom-team-avatar span {
  font-family: var(--font-display);
  font-size: .85rem;
  font-weight: 800;
  letter-spacing: -.02em;
}
.devcom-team-name {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: #f1f5f9;
  margin: 0 0 .2rem;
  line-height: 1.2;
}
.devcom-team-role {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .02em;
}

/* Bio */
.devcom-team-bio {
  font-size: .825rem;
  color: #64748b;
  line-height: 1.7;
  margin: 0;
  flex: 1;
}

/* Skill tags */
.devcom-team-skills {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-top: auto;
  padding-top: .75rem;
  border-top: 1px solid rgba(255,255,255,.06);
}
.devcom-skill-tag {
  display: inline-block;
  padding: .2rem .6rem;
  border-radius: 20px;
  border: 1px solid;
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .04em;
}

/* CTA */
.devcom-team-cta {
  text-align: center;
  padding: 2.5rem;
  background: rgba(0,120,212,.06);
  border: 1px solid rgba(0,120,212,.2);
  border-radius: 16px;
}
.devcom-team-cta p {
  color: #94a3b8;
  font-size: 1rem;
  margin: 0 0 1.25rem;
}

/* Responsive */
@media (max-width: 1024px) {
  .devcom-team-values { grid-template-columns: repeat(2, 1fr); }
  .devcom-team-grid   { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .devcom-team-values { grid-template-columns: 1fr; }
  .devcom-team-grid   { grid-template-columns: 1fr; }
}
/* Nav CSS → assets/css/woocommerce.css */

/* ============================================================
   CONTACT PAGE — DevCom v2.1.1
   ============================================================ */

/* ── Hero ── */
.contact-hero {
  position: relative;
  background: var(--clr-bg-dark);
  padding: 80px 0 64px;
  overflow: hidden;
}
.contact-hero__grid-lines {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(0,120,212,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,120,212,.08) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.contact-hero__content {
  max-width: 580px;
  position: relative;
  z-index: 1;
}
.contact-hero__content h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
  color: var(--clr-text-light);
  margin: 12px 0 16px;
  line-height: 1.1;
}
.contact-hero__content p {
  font-size: 1.05rem;
  color: rgba(255,255,255,.65);
  line-height: 1.7;
  margin: 0;
}
.contact-hero .hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--clr-accent-light);
}

/* ── Body grid ── */
.contact-body { padding-top: 64px; padding-bottom: 80px; }

.contact-grid {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 40px;
  align-items: start;
}

/* ── Info sidebar ── */
.contact-info__header { margin-bottom: 28px; }
.contact-info__header h2 {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--clr-text-heading);
  margin: 6px 0 8px;
}
.contact-info__header p { font-size: .9rem; color: var(--clr-text-muted); margin: 0; }

.contact-cards { display: flex; flex-direction: column; gap: 14px; }

.contact-card {
  display: flex;
  gap: 16px;
  padding: 20px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: 12px;
  transition: border-color .2s, box-shadow .2s;
}
.contact-card:hover {
  border-color: var(--clr-accent);
  box-shadow: 0 4px 20px var(--clr-accent-glow);
}

.contact-card__icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: 10px;
  background: var(--clr-blue-lt, #e6f3fb);
  background: rgba(0,120,212,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-accent);
}

.contact-card__body h3 {
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--clr-text-muted);
  margin: 0 0 8px;
}
.contact-card__body p {
  font-size: .9rem;
  color: var(--clr-text);
  margin: 0 0 6px;
  line-height: 1.5;
}
.contact-card__body p:last-child { margin-bottom: 0; }
.contact-card__body a {
  color: var(--clr-text);
  text-decoration: none;
  font-weight: 500;
}
.contact-card__body a:hover { color: var(--clr-accent); }
.contact-card__sub { font-size: .78rem; color: var(--clr-text-muted); }

.contact-card__link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--clr-accent) !important;
  margin-top: 8px;
  text-decoration: none;
}
.contact-card__link:hover { text-decoration: underline; }

/* Hours grid */
.hours-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 16px;
  font-size: .85rem;
}
.hours-grid span { color: var(--clr-text); }
.hours-grid span:nth-child(odd) { color: var(--clr-text-muted); }
.hours-closed { color: var(--clr-warning) !important; font-weight: 600; }

/* Social */
.contact-social {
  margin-top: 20px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.contact-social__label {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--clr-text-muted);
  margin: 0;
  white-space: nowrap;
}
.contact-social__links { display: flex; gap: 8px; }
.contact-social__links a {
  width: 36px; height: 36px;
  border-radius: 8px;
  border: 1px solid var(--clr-border);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-text-muted);
  transition: border-color .2s, color .2s, background .2s;
}
.contact-social__links a:hover {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
  background: rgba(0,120,212,.05);
}

/* ── Form Card ── */
.contact-form-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: 16px;
  padding: 36px 40px;
  box-shadow: 0 4px 32px rgba(0,0,0,.06);
}

.contact-form-card__header { margin-bottom: 28px; }
.contact-form-card__header h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--clr-text-heading);
  margin: 0 0 6px;
}
.contact-form-card__header p { font-size: .88rem; color: var(--clr-text-muted); margin: 0; }

/* Notice */
.contact-notice {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  border-radius: 8px;
  font-size: .88rem;
  font-weight: 500;
  margin-bottom: 24px;
}
.contact-notice--ok    { background: #dff6dd; color: #0c4a0a; border: 1px solid #a8d5a6; }
.contact-notice--error { background: #fde7e9; color: #7a1c1c; border: 1px solid #f5b4b1; }

/* Form fields */
.contact-form { display: flex; flex-direction: column; gap: 18px; }

.contact-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.contact-form__field label {
  font-size: .8rem;
  font-weight: 700;
  color: var(--clr-text);
  letter-spacing: .01em;
}
.contact-form__field label span { color: var(--clr-accent); margin-left: 2px; }

.contact-form__field input,
.contact-form__field select,
.contact-form__field textarea {
  width: 100%;
  padding: 11px 14px;
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--clr-text);
  background: var(--clr-bg-alt);
  border: 1.5px solid var(--clr-border);
  border-radius: 8px;
  outline: none;
  transition: border-color .18s, box-shadow .18s, background .18s;
  appearance: none;
  box-sizing: border-box;
}

.contact-form__field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236e6e6e' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
  cursor: pointer;
}

.contact-form__field input:focus,
.contact-form__field select:focus,
.contact-form__field textarea:focus {
  border-color: var(--clr-accent);
  background: #fff;
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}

.contact-form__field input::placeholder,
.contact-form__field textarea::placeholder { color: var(--clr-text-muted); opacity: .7; }

.contact-form__field textarea { resize: vertical; min-height: 140px; line-height: 1.6; }

/* Checkbox */
.contact-form__field--checkbox { flex-direction: row; align-items: flex-start; gap: 0; }
.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: .82rem;
  color: var(--clr-text-muted);
  line-height: 1.5;
}
.checkbox-label input[type="checkbox"] {
  width: 16px;
  min-width: 16px;
  height: 16px;
  margin-top: 2px;
  accent-color: var(--clr-accent);
  cursor: pointer;
  border: none;
  padding: 0;
}
.checkbox-label a { color: var(--clr-accent); text-decoration: underline; }

/* Actions */
.contact-form__actions {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-top: 4px;
}
.contact-form__submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.contact-form__note {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  color: var(--clr-text-muted);
  margin: 0;
}
.contact-form__note svg { flex-shrink: 0; color: var(--clr-success); }

/* ── Map ── */
.contact-map-section { padding: 0 0 80px; }
.contact-map-wrap {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--clr-border);
  box-shadow: 0 4px 24px rgba(0,0,0,.07);
}
.contact-map-wrap iframe { display: block; }
.contact-map-badge {
  position: absolute;
  bottom: 16px;
  left: 16px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--clr-bg-dark);
  color: var(--clr-text-light);
  font-size: .8rem;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 20px;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.contact-map-badge svg { color: var(--clr-accent); }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-info { order: 2; }
  .contact-form-wrap { order: 1; }
  .contact-cards { display: grid; grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .contact-form-card { padding: 24px 20px; }
  .contact-form__row { grid-template-columns: 1fr; gap: 14px; }
  .contact-form__actions { flex-direction: column; align-items: flex-start; }
  .contact-cards { grid-template-columns: 1fr; }
  .contact-hero { padding: 56px 0 44px; }
}

/* ============================================================
   ÜRÜN TAB SİSTEMİ — prd-tabs-section
   ============================================================ */

/* Tab bar */
.prd-tabs {
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 24px 0 28px;
  padding: 4px;
  background: #f1f3f5;
  border-radius: 14px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.prd-tabs::-webkit-scrollbar { display: none; }

.prd-tab {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  border: none;
  border-radius: 10px;
  background: transparent;
  color: #6b7280;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background .18s, color .18s, box-shadow .18s;
  font-family: inherit;
  flex-shrink: 0;
}
.prd-tab svg {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
  transition: stroke .18s;
}
.prd-tab:hover {
  background: #fff;
  color: #111827;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}
.prd-tab--active {
  background: #fff;
  color: var(--clr-accent, #0078d4);
  box-shadow: 0 2px 8px rgba(0,0,0,.10);
}
.prd-tab--active svg { stroke: var(--clr-accent, #0078d4); }

/* Tab panelleri */
.prd-panel {
  animation: prd-fade-in .22s ease;
}
@keyframes prd-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Boş durum */
.prd-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 60px 24px;
  text-align: center;
  color: #9ca3af;
}
.prd-empty svg { stroke: #d1d5db; }
.prd-empty p {
  font-size: .9rem;
  color: #6b7280;
  max-width: 360px;
  margin: 0;
}

/* Badge Türkçe */
.badge--sale     { background: var(--clr-accent, #0078d4); color: #fff; }
.badge--featured { background: #f59e0b; color: #fff; }
.badge--outofstock { background: #e5e7eb; color: #6b7280; font-size: .7rem; }
.badge--coming   { background: #8b5cf6; color: #fff; }

/* Ürün kartı — no-image fallback */
.product-card__no-img {
  width: 100%;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f8fafc;
}

/* Yakında satışta */
.prd-coming-soon {
  text-align: center;
  padding: 32px 0 16px;
}
.prd-coming-soon__icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(0,120,212,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  color: var(--clr-accent, #0078d4);
}
.prd-coming-soon h3 {
  font-size: 1.4rem;
  font-weight: 800;
  color: #0a0f1e;
  margin: 0 0 8px;
}
.prd-coming-soon > p {
  color: #6b7280;
  font-size: .9rem;
  margin: 0 auto 28px;
  max-width: 400px;
}
.prd-coming-grid { margin-top: 20px; }
.product-card--coming { opacity: .75; }
.product-card__coming-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.35);
  z-index: 2;
}
.product-card__coming-overlay span {
  background: #8b5cf6;
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* Responsive */
@media (max-width: 768px) {
  .prd-tabs { gap: 2px; padding: 3px; }
  .prd-tab { padding: 8px 12px; font-size: .78rem; }
  .prd-tab span { display: none; }
  .prd-tab svg { width: 18px; height: 18px; }
  .prd-tab--active span { display: inline; }
}
@media (max-width: 480px) {
  .prd-tab { padding: 8px 10px; }
  .prd-tab--active span { display: none; }
}

/* ============================================================
   DEVCOM TICKET — Hesabım bildirim CSS (tema içinde)
   ============================================================ */
.devcom-account__ticket-notice {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 20px;
  margin: 0 0 20px;
  background: linear-gradient(135deg, #eff6ff, #dbeafe);
  border: 1.5px solid #93c5fd;
  border-radius: 12px;
  text-decoration: none;
  color: #1e40af;
  transition: border-color .18s, box-shadow .18s, transform .18s;
}
.devcom-account__ticket-notice:hover {
  border-color: #3b82f6;
  box-shadow: 0 4px 20px rgba(59,130,246,.2);
  transform: translateY(-1px);
  color: #1e40af;
}
.devcom-account__ticket-notice__icon {
  position: relative;
  width: 44px; height: 44px;
  background: #2563eb;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  flex-shrink: 0;
}
.devcom-account__ticket-pulse {
  position: absolute;
  top: -3px; right: -3px;
  width: 14px; height: 14px;
  background: #ef4444;
  border-radius: 50%;
  border: 2px solid #fff;
  animation: dct-pulse-anim 1.4s ease infinite;
}
@keyframes dct-pulse-anim {
  0%   { transform: scale(1); opacity: 1; }
  50%  { transform: scale(1.4); opacity: .55; }
  100% { transform: scale(1); opacity: 1; }
}
.devcom-account__ticket-notice__text {
  display: flex; flex-direction: column; gap: 2px;
}
.devcom-account__ticket-notice__text strong {
  font-size: .95rem; font-weight: 700; color: #1e3a8a;
}
.devcom-account__ticket-notice__text span {
  font-size: .8rem; color: #3b82f6;
}
/* Badge — hesabım sidebar menü */
.dct-account-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: #ef4444; color: #fff;
  font-size: .65rem; font-weight: 800;
  border-radius: 9px; margin-left: 6px;
  animation: dct-badge-blink 1.6s ease infinite;
}
@keyframes dct-badge-blink { 0%,100%{opacity:1} 50%{opacity:.6} }

/* ============================================================
   HESABIM SAYFASI — devcom-account  v3.1  Açık & Kompakt
   ============================================================ */

.devcom-account {
  background: #ffffff;
  min-height: 60vh;
  padding: 24px 0 48px;
}
.devcom-account__container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ── Banner — beyaz, ince mavi aksan ── */
.devcom-account__banner {
  background: #0a0a0a;
  background-image:
    radial-gradient(ellipse 55% 120% at 85% 50%, rgba(99,102,241,.18) 0%, transparent 65%),
    radial-gradient(ellipse 35% 70% at 5% 30%, rgba(59,130,246,.12) 0%, transparent 55%);
  border-radius: 14px;
  padding: 20px 28px;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.18);
}
.devcom-account__banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}
.devcom-account__banner::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(99,102,241,.5), rgba(59,130,246,.5), transparent);
}

.devcom-account__avatar-wrap { position: relative; flex-shrink: 0; }
.devcom-account__avatar-img {
  width: 60px !important;
  height: 60px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(99,102,241,.5) !important;
  object-fit: cover;
  display: block;
  box-shadow: 0 0 0 3px rgba(99,102,241,.2);
}
.devcom-account__avatar-initial {
  display: flex; align-items: center; justify-content: center;
  width: 60px; height: 60px; border-radius: 50%;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
  font-size: 20px; font-weight: 700;
  box-shadow: 0 0 0 3px rgba(99,102,241,.3), 0 0 20px rgba(99,102,241,.2);
  border: none;
}

.devcom-account__info { flex: 1; min-width: 0; }
.devcom-account__name {
  color: #fff;
  font-size: 1.15rem; font-weight: 700;
  margin: 0 0 3px; line-height: 1.3;
}
.devcom-account__name span {
  background: linear-gradient(90deg, #818cf8, #a78bfa);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.devcom-account__email { color: rgba(255,255,255,.4); font-size: .82rem; margin: 0; }

.devcom-account__stats {
  display: flex; gap: 0; margin-left: auto;
}
.devcom-account__stat {
  text-align: center; padding: 0 16px;
  border-left: 1px solid rgba(255,255,255,.08);
}
.devcom-account__stat:first-child { border-left: none; }
.devcom-account__stat-val {
  display: block; font-size: 1.25rem; font-weight: 700;
  color: #fff; line-height: 1; margin-bottom: 3px;
}
.devcom-account__stat-lbl {
  display: block; font-size: .65rem; font-weight: 600;
  color: rgba(255,255,255,.35); text-transform: uppercase; letter-spacing: .06em;
}

/* ── Destek bildirimi ── */
.devcom-account__ticket-notice--always { display: flex !important; margin-bottom: 14px; }
.devcom-account__ticket-notice {
  display: flex; align-items: center; gap: 12px;
  background: #EBF5FF;
  border: 1px solid #B5D4F4;
  border-radius: 10px;
  padding: 10px 16px;
  margin-bottom: 14px;
  text-decoration: none; color: #1e293b;
  transition: border-color .15s, background .15s;
}
.devcom-account__ticket-notice:hover {
  background: #dbeafe; border-color: #378ADD; color: #1e293b;
}
.devcom-account__ticket-notice__icon {
  position: relative; flex-shrink: 0;
  width: 36px; height: 36px;
  background: #fff; border-radius: 8px;
  border: 1px solid #B5D4F4;
  display: flex; align-items: center; justify-content: center;
  color: #185FA5;
}
.devcom-account__ticket-pulse {
  position: absolute; top: -3px; right: -3px;
  width: 10px; height: 10px;
  background: #f97316; border-radius: 50%;
  border: 2px solid #EBF5FF;
  animation: dct-pulse 1.5s infinite;
}
@keyframes dct-pulse {
  0%,100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.35); opacity: .6; }
}
.devcom-account__ticket-notice__text { display: flex; flex-direction: column; gap: 1px; }
.devcom-account__ticket-notice__text strong { font-size: .875rem; font-weight: 700; color: #185FA5; }
.devcom-account__ticket-notice__text span   { font-size: .78rem; color: #64748b; }

/* ── Ana layout ── */
.devcom-account__layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 16px;
  align-items: start;
}
@media (max-width: 768px) {
  .devcom-account__layout { grid-template-columns: 1fr; }
  .devcom-account__banner { flex-direction: column; text-align: center; padding: 18px; }
  .devcom-account__stats  { margin: 10px auto 0; justify-content: center; }
}

/* ── Sidebar nav ── */
.devcom-account__nav {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
  position: sticky; top: 90px;
}
.devcom-account__nav-item {
  display: flex; align-items: center; gap: 9px;
  padding: 10px 14px;
  color: #475569; text-decoration: none;
  font-size: .8rem; font-weight: 600;
  border-bottom: 1px solid #f1f5f9;
  transition: background .12s, color .12s, padding-left .12s;
  position: relative;
}
.devcom-account__nav-item:last-child { border-bottom: none; }
.devcom-account__nav-item:hover {
  background: #f8fafc; color: #185FA5; padding-left: 18px;
}
.devcom-account__nav-item--active {
  background: #EBF5FF; color: #185FA5;
  border-left: 3px solid #185FA5; padding-left: 17px;
}
.devcom-account__nav-item--logout { color: #ef4444; }
.devcom-account__nav-item--logout:hover { background: #fff5f5; color: #dc2626; }
.devcom-account__nav-icon { display: flex; align-items: center; justify-content: center; width: 18px; flex-shrink: 0; opacity: .65; color: currentColor; }
.devcom-account__nav-label { flex: 1; }
.devcom-account__nav-arrow { margin-left: auto; opacity: .3; flex-shrink: 0; }

.devcom-account__nav-badge {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px;
  background: #f97316; color: #fff;
  font-size: .65rem; font-weight: 800; border-radius: 9px; padding: 0 4px;
  margin-right: 2px;
}
.devcom-account__nav-pulse {
  position: absolute; inset: -3px; border-radius: 50%;
  background: #f97316; opacity: .35;
  animation: dct-nav-pulse 1.5s ease-in-out infinite;
}
@keyframes dct-nav-pulse {
  0%,100% { transform: scale(1); opacity: .35; }
  50%      { transform: scale(1.5); opacity: 0; }
}

/* ── İçerik alanı ── */
.devcom-account__content {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 22px 24px;
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
  min-height: 280px;
}
.devcom-account__content h2 {
  font-size: 1rem; font-weight: 700; color: #0f172a;
  margin: 0 0 18px; padding-bottom: 12px;
  border-bottom: 1px solid #f1f5f9;
}
.devcom-account__content h3 {
  font-size: .9rem; font-weight: 700; color: #1e293b; margin: 0 0 10px;
}

/* ── Form alanları — 2 kolonlu grid ── */
.devcom-account__content .woocommerce-form,
.devcom-account__content form.woocommerce-EditAccountForm,
.devcom-account__content form.edit-account {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 16px;
}
.devcom-account__content .woocommerce-form-row--wide,
.devcom-account__content .form-row-wide,
.devcom-account__content fieldset,
.devcom-account__content .clear { grid-column: 1 / -1; }

.devcom-account__content fieldset {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.devcom-account__content fieldset legend {
  font-size: .78rem;
  font-weight: 700;
  color: #374151;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 0;
  margin-bottom: 12px;
  float: none;
  width: auto;
}

.devcom-account__content .woocommerce-form-row,
.devcom-account__content .form-row {
  display: flex; flex-direction: column; gap: 4px; margin-bottom: 0 !important;
}
.devcom-account__content .woocommerce-form-row label,
.devcom-account__content .form-row label {
  display: block; font-size: .72rem; font-weight: 700;
  color: #64748b; text-transform: uppercase; letter-spacing: .04em;
}
.devcom-account__content .woocommerce-form-row label abbr,
.devcom-account__content .form-row label abbr { color: #ef4444; text-decoration: none; margin-left: 1px; }

.devcom-account__content .woocommerce-form-row input[type="text"],
.devcom-account__content .woocommerce-form-row input[type="email"],
.devcom-account__content .woocommerce-form-row input[type="password"],
.devcom-account__content .woocommerce-form-row input[type="tel"],
.devcom-account__content .form-row input[type="text"],
.devcom-account__content .form-row input[type="email"],
.devcom-account__content .form-row input[type="password"],
.devcom-account__content .form-row input[type="tel"],
.devcom-account__content .form-row select,
.devcom-account__content .woocommerce-form-row select {
  width: 100% !important; height: 38px;
  padding: 0 12px;
  border: 1px solid #e2e8f0; border-radius: 8px;
  font-size: .85rem; color: #0f172a;
  background: #f8fafc; font-family: inherit;
  transition: border-color .15s, box-shadow .15s, background .15s;
  box-sizing: border-box; margin: 0 !important;
}
.devcom-account__content .form-row input:focus,
.devcom-account__content .form-row select:focus,
.devcom-account__content .woocommerce-form-row input:focus,
.devcom-account__content .woocommerce-form-row select:focus {
  border-color: #378ADD; box-shadow: 0 0 0 3px rgba(55,138,221,.1);
  outline: none; background: #fff;
}
.devcom-account__content .form-row select,
.devcom-account__content .woocommerce-form-row select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2394a3b8' stroke-width='1.2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; padding-right: 32px;
}

/* Butonlar */
.devcom-account__content .woocommerce-Button,
.devcom-account__content .button,
.devcom-account__content button[type="submit"],
.devcom-account__content input[type="submit"] {
  display: inline-flex !important; align-items: center; justify-content: center;
  height: 38px; padding: 0 20px;
  background: #185FA5; color: #fff !important;
  border: none; border-radius: 8px;
  font-size: .82rem; font-weight: 700; cursor: pointer;
  text-decoration: none; font-family: inherit;
  transition: background .15s; white-space: nowrap;
}
.devcom-account__content .woocommerce-Button:hover,
.devcom-account__content .button:hover,
.devcom-account__content button[type="submit"]:hover,
.devcom-account__content input[type="submit"]:hover {
  background: #0C447C; color: #fff !important;
}

/* Adres kartları */
.devcom-account__content .woocommerce-Addresses {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.devcom-account__content .woocommerce-Address {
  background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px; padding: 16px;
  transition: border-color .15s;
}
.devcom-account__content .woocommerce-Address:hover { border-color: #378ADD; }
.devcom-account__content .woocommerce-Address-title {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid #e8edf2;
}
.devcom-account__content .woocommerce-Address-title h3 {
  font-size: .78rem; font-weight: 700; color: #475569;
  text-transform: uppercase; letter-spacing: .05em; margin: 0;
}
.devcom-account__content address { font-style: normal; font-size: .82rem; color: #374151; line-height: 1.75; }

/* Sipariş tablosu */
.devcom-account__content table.shop_table { width: 100%; border-collapse: collapse; font-size: .82rem; }
.devcom-account__content table.shop_table th {
  padding: 8px 12px; text-align: left; font-size: .68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; color: #64748b;
  border-bottom: 2px solid #f1f5f9; background: #f8fafc; white-space: nowrap;
}
.devcom-account__content table.shop_table td {
  padding: 10px 12px; border-bottom: 1px solid #f8fafc; color: #1e293b; vertical-align: middle;
}
.devcom-account__content table.shop_table tr:last-child td { border-bottom: none; }
.devcom-account__content table.shop_table tr:hover td { background: #fafbfc; }
.devcom-account__content .woocommerce-orders-table .order-number a { color: #185FA5; font-weight: 700; text-decoration: none; }
.devcom-account__content .woocommerce-orders-table .order-status {
  display: inline-flex; align-items: center; height: 21px; padding: 0 8px;
  border-radius: 10px; font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
}
.devcom-account__content .order-status.wc-completed,
.devcom-account__content .order-status.status-completed  { background: #EAF3DE; color: #3B6D11; }
.devcom-account__content .order-status.wc-processing,
.devcom-account__content .order-status.status-processing { background: #E6F1FB; color: #185FA5; }
.devcom-account__content .order-status.wc-pending,
.devcom-account__content .order-status.status-pending    { background: #FAEEDA; color: #854F0B; }
.devcom-account__content .order-status.wc-cancelled,
.devcom-account__content .order-status.status-cancelled  { background: #FCEBEB; color: #A32D2D; }
.devcom-account__content .order-status.wc-on-hold        { background: #EEEDFE; color: #534AB7; }
.devcom-account__content .order-status.wc-refunded       { background: #f1f5f9; color: #475569; }

/* WC notices */
.devcom-account__content .woocommerce-message,
.devcom-account__content .woocommerce-error,
.devcom-account__content .woocommerce-info {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: 8px;
  font-size: .82rem; font-weight: 600; margin-bottom: 16px;
  border: none; list-style: none;
}
.devcom-account__content .woocommerce-message { background: #EAF3DE; color: #3B6D11; }
.devcom-account__content .woocommerce-error   { background: #FCEBEB; color: #A32D2D; }
.devcom-account__content .woocommerce-info    { background: #E6F1FB; color: #185FA5; }
.devcom-account__content .woocommerce-MyAccount-content p { font-size: .875rem; color: #374151; line-height: 1.7; margin-bottom: 10px; }

@media (max-width: 620px) {
  .devcom-account__content { padding: 16px; }
  .devcom-account__content .woocommerce-form,
  .devcom-account__content form.woocommerce-EditAccountForm { grid-template-columns: 1fr; }
  .devcom-account__content .woocommerce-Addresses { grid-template-columns: 1fr; }
}

/* ── Hesabım sayfa başlığı — küçük, profesyonel ── */
.woocommerce-account h1.page-title,
.woocommerce-account .page-title {
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: #64748b !important;
  letter-spacing: .01em !important;
  margin: 0 0 16px !important;
  padding: 14px 0 10px !important;
  text-transform: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  border-bottom: none !important;
}
.woocommerce-account h1.page-title::before,
.woocommerce-account .page-title::before {
  content: '' !important;
  display: inline-block !important;
  width: 3px !important;
  height: 16px !important;
  background: #0078d4 !important;
  border-radius: 2px !important;
  flex-shrink: 0 !important;
}

/* ══════════════════════════════════════════
   404 HATA SAYFASI — Profesyonel Tasarım
   ══════════════════════════════════════════ */

.dv404 {
  min-height: 80vh;
  display: flex;
  align-items: center;
  background: #fff;
}

.dv404__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 60px 24px;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 60px;
  align-items: center;
}

/* ── Sol: İçerik ── */
.dv404__badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 20px;
  padding: 5px 14px;
  font-size: .78rem;
  font-weight: 700;
  color: #1d4ed8;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.dv404__badge-dot {
  width: 7px; height: 7px;
  background: #3b82f6;
  border-radius: 50%;
  animation: dv404-pulse 1.5s ease-in-out infinite;
}
@keyframes dv404-pulse {
  0%,100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.4); opacity: .6; }
}

.dv404__num {
  font-size: 8rem;
  font-weight: 900;
  color: #f1f5f9;
  letter-spacing: -.05em;
  line-height: 1;
  margin-bottom: -16px;
  background: linear-gradient(135deg, #e2e8f0, #f8fafc);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  user-select: none;
}

.dv404__title {
  font-size: 2.2rem;
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 16px;
  line-height: 1.2;
  letter-spacing: -.02em;
}

.dv404__desc {
  font-size: 1rem;
  color: #64748b;
  line-height: 1.75;
  margin: 0 0 32px;
  max-width: 480px;
}

/* ── Butonlar ── */
.dv404__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}

.dv404__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: 10px;
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
  transition: transform .15s, box-shadow .15s, background .15s;
}
.dv404__btn:hover { transform: translateY(-2px); text-decoration: none; }

.dv404__btn--primary {
  background: #0f172a;
  color: #fff;
  box-shadow: 0 4px 14px rgba(15,23,42,.2);
}
.dv404__btn--primary:hover {
  background: #1e293b;
  box-shadow: 0 6px 20px rgba(15,23,42,.3);
  color: #fff;
}

.dv404__btn--outline {
  background: #fff;
  color: #0f172a;
  border: 1.5px solid #e2e8f0;
}
.dv404__btn--outline:hover {
  border-color: #0078d4;
  color: #0078d4;
  background: #eff6ff;
}

/* ── Arama ── */
.dv404__search-label {
  font-size: .82rem;
  font-weight: 600;
  color: #94a3b8;
  margin: 0 0 10px;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.dv404__search-wrap {
  display: flex;
  align-items: center;
  gap: 0;
  background: #f8fafc;
  border: 1.5px solid #e2e8f0;
  border-radius: 10px;
  padding: 0 4px 0 14px;
  transition: border-color .18s, box-shadow .18s;
  max-width: 460px;
}
.dv404__search-wrap:focus-within {
  border-color: #0078d4;
  box-shadow: 0 0 0 3px rgba(0,120,212,.1);
  background: #fff;
}
.dv404__search-wrap svg { color: #94a3b8; flex-shrink: 0; }

.dv404__search-input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 12px 10px;
  font-size: .9rem;
  color: #0f172a;
  outline: none;
  font-family: inherit;
}
.dv404__search-input::placeholder { color: #94a3b8; }

.dv404__search-btn {
  height: 36px;
  padding: 0 16px;
  background: #0078d4;
  color: #fff;
  border: none;
  border-radius: 7px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s;
  flex-shrink: 0;
}
.dv404__search-btn:hover { background: #005fa3; }

/* ── Sağ: Görsel ── */
.dv404__visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dv404__visual-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, #eff6ff 0%, transparent 70%);
  border-radius: 50%;
}

.dv404__visual-num {
  position: absolute;
  font-size: 11rem;
  font-weight: 900;
  color: #e2e8f0;
  letter-spacing: -.05em;
  user-select: none;
  z-index: 0;
  line-height: 1;
}

.dv404__visual-icon {
  position: relative;
  z-index: 1;
  width: 240px;
  height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: dv404-float 3s ease-in-out infinite;
}
.dv404__visual-icon svg { width: 100%; height: 100%; }

@keyframes dv404-float {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-12px); }
}

/* Responsive */
@media (max-width: 860px) {
  .dv404__inner {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 48px 20px;
    gap: 36px;
  }
  .dv404__visual { order: -1; }
  .dv404__visual-num { font-size: 7rem; }
  .dv404__visual-icon { width: 180px; height: 180px; }
  .dv404__badge { margin: 0 auto 20px; }
  .dv404__desc { margin-left: auto; margin-right: auto; }
  .dv404__actions { justify-content: center; }
  .dv404__search-wrap { max-width: 100%; }
  .dv404__num { font-size: 5rem; }
  .dv404__title { font-size: 1.7rem; }
}
