/* ==========================================================================
   Kapadokya Hediyelik — Vitrin Stili
   Mobil öncelikli. Turuncu/krem/toprak. Kendi CSS'i (framework yok).
   ========================================================================== */

:root {
  --turuncu:       #E8743B;
  --turuncu-koyu:  #cf5f2a;
  --turuncu-acik:  #fbe9df;
  --krem:          #FAF6EF;
  --krem-koyu:     #F1E9DC;
  --toprak:        #8a6d52;
  --metin:         #2B2420;
  --metin-acik:    #6f6258;
  --beyaz:         #ffffff;
  --cizgi:         #ece4d6;
  --yesil:         #2f9e6b;
  --kirmizi:       #d1495b;
  --sari:          #e9b949;
  --golge-sm:      0 1px 3px rgba(43,36,32,.08);
  --golge:         0 6px 22px rgba(43,36,32,.09);
  --golge-lg:      0 18px 48px rgba(43,36,32,.16);
  --radius:        14px;
  --radius-sm:     10px;
  --gecis:         .2s ease;
  --en:            1200px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

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

body {
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  color: var(--metin);
  background: var(--krem);
  line-height: 1.6;
  font-size: 16px;
  overflow-x: hidden;
}

h1, h2, h3, h4 {
  font-family: 'Poppins', 'Inter', sans-serif;
  font-weight: 600;
  line-height: 1.2;
  color: var(--metin);
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; font-size: 1rem; }

.container { width: 100%; max-width: var(--en); margin: 0 auto; padding: 0 18px; }

.kucuk { font-size: .86rem; }
.metin-acik { color: var(--metin-acik); }
.tam-genislik { width: 100%; }
.merkez { text-align: center; }
.gizli { display: none !important; }

/* ---------- İkonlar ---------- */
.ikon { width: 20px; height: 20px; stroke-width: 2; flex: none; }
.ikon-sm { width: 16px; height: 16px; }
.ikon-lg { width: 28px; height: 28px; }

/* ---------- Butonlar ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .72rem 1.4rem; border-radius: var(--radius-sm); font-weight: 600;
  font-size: .95rem; transition: var(--gecis); white-space: nowrap; line-height: 1;
  border: 2px solid transparent;
}
.btn-birincil { background: var(--turuncu); color: #fff; box-shadow: 0 6px 16px rgba(232,116,59,.28); }
.btn-birincil:hover { background: var(--turuncu-koyu); transform: translateY(-2px); box-shadow: 0 10px 22px rgba(232,116,59,.34); }
.btn-ikincil { background: var(--beyaz); color: var(--metin); border-color: var(--cizgi); }
.btn-ikincil:hover { border-color: var(--turuncu); color: var(--turuncu); }
.btn-hayalet { background: transparent; color: var(--metin); }
.btn-hayalet:hover { background: var(--krem-koyu); }
.btn-blok { width: 100%; }
.btn-buyuk { padding: .95rem 1.8rem; font-size: 1.02rem; }
.btn-kucuk { padding: .5rem .9rem; font-size: .85rem; }
.btn-tehlike { background: var(--kirmizi); color: #fff; }
.btn-tehlike:hover { filter: brightness(.93); }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

/* ---------- Rozetler ---------- */
.rozet {
  display: inline-flex; align-items: center; gap: .3rem; padding: .25rem .6rem;
  border-radius: 999px; font-size: .74rem; font-weight: 700; letter-spacing: .02em;
}
.rozet-indirim { background: var(--kirmizi); color: #fff; }
.rozet-yeni { background: var(--yesil); color: #fff; }
.rozet-stok-yok { background: #b9b0a5; color: #fff; }
.rozet-yumusak { background: var(--turuncu-acik); color: var(--turuncu-koyu); }

/* ---------- Duyuru çubuğu ---------- */
.duyuru {
  background: var(--metin); color: #f4ede2; text-align: center;
  font-size: .82rem; padding: .5rem 1rem; letter-spacing: .01em;
}
.duyuru strong { color: var(--turuncu); }

/* ---------- Üst başlık / nav ---------- */
.ust-bar {
  position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px); border-bottom: 1px solid var(--cizgi);
}
.nav {
  display: flex; align-items: center; gap: 1.2rem;
  height: 70px;
}
.logo { display: flex; align-items: center; gap: .55rem; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 1.25rem; }
.logo-ikon {
  width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--turuncu), #f0a55f); color: #fff; flex: none;
}
.logo span b { color: var(--turuncu); }

.nav-linkler { display: none; align-items: center; gap: .3rem; margin-left: 1rem; }
.nav-linkler a {
  padding: .5rem .85rem; border-radius: var(--radius-sm); font-weight: 500; font-size: .95rem;
  color: var(--metin-acik); transition: var(--gecis);
}
.nav-linkler a:hover, .nav-linkler a.aktif { color: var(--turuncu); background: var(--turuncu-acik); }

.nav-sag { margin-left: auto; display: flex; align-items: center; gap: .4rem; }
.ikon-btn {
  position: relative; width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center;
  color: var(--metin); transition: var(--gecis);
}
.ikon-btn:hover { background: var(--krem-koyu); color: var(--turuncu); }
.sepet-rozet {
  position: absolute; top: 4px; right: 4px; min-width: 18px; height: 18px; padding: 0 4px;
  background: var(--turuncu); color: #fff; border-radius: 999px; font-size: .68rem;
  font-weight: 700; display: grid; place-items: center; line-height: 1;
}
.menu-btn { display: grid; }

/* ---------- Mobil menü ---------- */
.mobil-menu {
  position: fixed; inset: 0 0 0 auto; width: min(82vw, 340px); background: #fff;
  box-shadow: var(--golge-lg); z-index: 100; transform: translateX(100%);
  transition: transform .28s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column;
  padding: 1.2rem;
}
.mobil-menu.acik { transform: translateX(0); }
.mobil-ortu {
  position: fixed; inset: 0; background: rgba(43,36,32,.45); z-index: 99; opacity: 0;
  pointer-events: none; transition: opacity .28s;
}
.mobil-ortu.acik { opacity: 1; pointer-events: auto; }
.mobil-menu a {
  padding: .85rem .6rem; border-radius: var(--radius-sm); font-weight: 500; display: flex;
  align-items: center; gap: .7rem; border-bottom: 1px solid var(--cizgi);
}
.mobil-menu a:hover { color: var(--turuncu); }
.mobil-menu-kapat { align-self: flex-end; }

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden; border-radius: 0; padding: 0;
  background: linear-gradient(135deg, #fff7ef 0%, var(--krem) 60%);
}
.hero-ic {
  display: grid; grid-template-columns: 1fr; gap: 2rem; align-items: center;
  padding: 3rem 0 3.5rem;
}
.hero-yazi h1 { font-size: 2.1rem; letter-spacing: -.02em; margin-bottom: 1rem; }
.hero-yazi h1 em { color: var(--turuncu); font-style: normal; }
.hero-yazi p { color: var(--metin-acik); font-size: 1.08rem; max-width: 30rem; margin-bottom: 1.6rem; }
.hero-butonlar { display: flex; gap: .8rem; flex-wrap: wrap; }
.hero-gorsel {
  position: relative; aspect-ratio: 4/3; border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--golge-lg); background: linear-gradient(135deg,#f3c9a3,#e8743b);
}
.hero-gorsel img { width: 100%; height: 100%; object-fit: cover; }
.hero-rozetler { display: flex; gap: 1.4rem; margin-top: 1.8rem; flex-wrap: wrap; }
.hero-rozet { display: flex; align-items: center; gap: .55rem; font-size: .9rem; color: var(--metin-acik); }
.hero-rozet .ikon { color: var(--turuncu); }

/* ---------- Bölüm başlığı ---------- */
.bolum { padding: 3rem 0; }
.bolum-bas { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 1.6rem; gap: 1rem; flex-wrap: wrap; }
.bolum-bas h2 { font-size: 1.6rem; }
.bolum-bas p { color: var(--metin-acik); font-size: .95rem; margin-top: .25rem; }
.bolum-bas a { color: var(--turuncu); font-weight: 600; font-size: .92rem; display: inline-flex; align-items: center; gap: .3rem; }

/* ---------- Kategori şeritleri ---------- */
.kategori-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: .9rem; }
.kategori-kart {
  background: #fff; border: 1px solid var(--cizgi); border-radius: var(--radius); padding: 1.1rem;
  display: flex; align-items: center; gap: .8rem; transition: var(--gecis);
}
.kategori-kart:hover { border-color: var(--turuncu); transform: translateY(-3px); box-shadow: var(--golge); }
.kategori-ikon { width: 46px; height: 46px; border-radius: 12px; background: var(--turuncu-acik); color: var(--turuncu-koyu); display: grid; place-items: center; flex: none; }
.kategori-kart b { font-size: .98rem; }
.kategori-kart small { color: var(--metin-acik); }

/* ---------- Ürün grid & kart ---------- */
.urun-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.1rem; }
.urun-kart {
  background: #fff; border: 1px solid var(--cizgi); border-radius: var(--radius); overflow: hidden;
  display: flex; flex-direction: column; transition: var(--gecis); position: relative;
}
.urun-kart:hover { transform: translateY(-5px); box-shadow: var(--golge-lg); border-color: transparent; }
.urun-gorsel {
  position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--krem-koyu);
  display: grid; place-items: center;
}
.urun-gorsel img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.urun-kart:hover .urun-gorsel img { transform: scale(1.06); }
.urun-gorsel-bos { color: #cabda9; }
.urun-rozetler { position: absolute; top: .6rem; left: .6rem; display: flex; flex-direction: column; gap: .35rem; }
.urun-bilgi { padding: .9rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.urun-kategori-etiket { font-size: .72rem; color: var(--turuncu); font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
.urun-ad { font-size: .98rem; font-weight: 600; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.urun-fiyat-satir { display: flex; align-items: baseline; gap: .5rem; margin-top: auto; flex-wrap: wrap; }
.urun-fiyat { font-size: 1.18rem; font-weight: 700; color: var(--metin); font-family: 'Poppins',sans-serif; }
.urun-fiyat-eski { font-size: .9rem; color: var(--metin-acik); text-decoration: line-through; }
.urun-alt { display: flex; gap: .5rem; padding: 0 .9rem .9rem; }
.urun-alt .btn { flex: 1; }

/* ---------- Ürün detay ---------- */
.detay-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
.detay-galeri { display: flex; flex-direction: column; gap: .8rem; }
.detay-ana-gorsel { aspect-ratio: 1/1; border-radius: var(--radius); overflow: hidden; background: var(--krem-koyu); box-shadow: var(--golge); display: grid; place-items: center; }
.detay-ana-gorsel img { width: 100%; height: 100%; object-fit: cover; }
.detay-kucukler { display: flex; gap: .55rem; flex-wrap: wrap; }
.detay-kucuk { width: 68px; height: 68px; border-radius: 10px; overflow: hidden; border: 2px solid var(--cizgi); cursor: pointer; transition: var(--gecis); }
.detay-kucuk.aktif, .detay-kucuk:hover { border-color: var(--turuncu); }
.detay-kucuk img { width: 100%; height: 100%; object-fit: cover; }
.detay-bilgi h1 { font-size: 1.7rem; margin: .4rem 0 .8rem; }
.detay-fiyat-kutu { display: flex; align-items: baseline; gap: .8rem; margin: 1rem 0; }
.detay-fiyat { font-size: 2rem; font-weight: 700; color: var(--turuncu); font-family: 'Poppins',sans-serif; }
.detay-fiyat-eski { font-size: 1.15rem; color: var(--metin-acik); text-decoration: line-through; }
.detay-aciklama { color: var(--metin-acik); margin: 1.2rem 0; line-height: 1.8; }
.detay-stok { display: inline-flex; align-items: center; gap: .4rem; font-size: .9rem; font-weight: 600; }
.detay-stok.var { color: var(--yesil); }
.detay-stok.yok { color: var(--kirmizi); }
.detay-sepet-satir { display: flex; gap: .8rem; align-items: stretch; margin-top: 1.4rem; flex-wrap: wrap; }

/* ---------- Adet sayacı ---------- */
.adet { display: inline-flex; align-items: center; border: 2px solid var(--cizgi); border-radius: var(--radius-sm); overflow: hidden; }
.adet button { width: 42px; height: 46px; display: grid; place-items: center; color: var(--metin); transition: var(--gecis); }
.adet button:hover { background: var(--krem-koyu); color: var(--turuncu); }
.adet input { width: 48px; height: 46px; text-align: center; border: none; border-left: 2px solid var(--cizgi); border-right: 2px solid var(--cizgi); font-weight: 600; -moz-appearance: textfield; }
.adet input::-webkit-outer-spin-button, .adet input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* ---------- Sepet ---------- */
.sepet-duzen { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.sepet-satir {
  display: grid; grid-template-columns: 80px 1fr auto; gap: 1rem; align-items: center;
  background: #fff; border: 1px solid var(--cizgi); border-radius: var(--radius); padding: .9rem;
}
.sepet-gorsel { width: 80px; height: 80px; border-radius: 10px; overflow: hidden; background: var(--krem-koyu); }
.sepet-gorsel img { width: 100%; height: 100%; object-fit: cover; }
.sepet-orta b { display: block; font-size: .98rem; }
.sepet-orta small { color: var(--metin-acik); }
.sepet-sag { display: flex; flex-direction: column; align-items: flex-end; gap: .5rem; }
.sepet-sil { color: var(--kirmizi); display: inline-flex; align-items: center; gap: .3rem; font-size: .82rem; }
.sepet-sil:hover { text-decoration: underline; }
.ozet-kart { background: #fff; border: 1px solid var(--cizgi); border-radius: var(--radius); padding: 1.4rem; box-shadow: var(--golge-sm); position: sticky; top: 90px; }
.ozet-kart h3 { font-size: 1.15rem; margin-bottom: 1rem; }
.ozet-satir { display: flex; justify-content: space-between; padding: .55rem 0; color: var(--metin-acik); font-size: .95rem; }
.ozet-satir.toplam { border-top: 2px dashed var(--cizgi); margin-top: .5rem; padding-top: 1rem; color: var(--metin); font-weight: 700; font-size: 1.2rem; }
.ozet-satir.toplam span:last-child { color: var(--turuncu); }
.bos-durum { text-align: center; padding: 4rem 1rem; color: var(--metin-acik); }
.bos-durum .ikon-cember { width: 80px; height: 80px; margin: 0 auto 1.2rem; border-radius: 50%; background: var(--krem-koyu); display: grid; place-items: center; color: var(--turuncu); }
.bos-durum h3 { color: var(--metin); margin-bottom: .5rem; }

/* ---------- Formlar / checkout / auth ---------- */
.form-kart { background: #fff; border: 1px solid var(--cizgi); border-radius: var(--radius); padding: 1.6rem; box-shadow: var(--golge-sm); }
.alan { margin-bottom: 1.1rem; }
.alan label { display: block; font-weight: 600; font-size: .9rem; margin-bottom: .4rem; }
.alan label .zorunlu { color: var(--kirmizi); }
.girdi {
  width: 100%; padding: .8rem .95rem; border: 2px solid var(--cizgi); border-radius: var(--radius-sm);
  background: var(--krem); transition: var(--gecis); color: var(--metin);
}
.girdi:focus { outline: none; border-color: var(--turuncu); background: #fff; box-shadow: 0 0 0 4px var(--turuncu-acik); }
textarea.girdi { resize: vertical; min-height: 110px; }
.alan-hata { color: var(--kirmizi); font-size: .82rem; margin-top: .35rem; }
.form-ikili { display: grid; grid-template-columns: 1fr; gap: 0 1rem; }
.auth-sayfa { max-width: 440px; margin: 2.5rem auto; }
.auth-sayfa h1 { text-align: center; font-size: 1.6rem; margin-bottom: .4rem; }
.auth-alt { text-align: center; margin-top: 1.2rem; color: var(--metin-acik); font-size: .92rem; }
.auth-alt a { color: var(--turuncu); font-weight: 600; }

.checkout-duzen { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }

/* ---------- Hesabım ---------- */
.hesap-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.bilgi-kart { background:#fff; border:1px solid var(--cizgi); border-radius: var(--radius); padding: 1.4rem; }
.tablo { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--golge-sm); }
.tablo th, .tablo td { padding: .85rem 1rem; text-align: left; border-bottom: 1px solid var(--cizgi); font-size: .92rem; }
.tablo th { background: var(--krem-koyu); font-weight: 600; font-size: .82rem; text-transform: uppercase; letter-spacing: .03em; color: var(--metin-acik); }
.tablo tr:last-child td { border-bottom: none; }
.tablo-sar { overflow-x: auto; }

/* ---------- Durum etiketi ---------- */
.durum { display: inline-flex; align-items: center; gap: .35rem; padding: .3rem .65rem; border-radius: 999px; font-size: .76rem; font-weight: 700; }
.durum-beklemede   { background: #fff3d6; color: #9a6b00; }
.durum-odendi      { background: #dff3e6; color: #1f7a4d; }
.durum-hazirlaniyor{ background: #e2ecff; color: #2b56b5; }
.durum-kargoda     { background: #e6e2ff; color: #5a3fb5; }
.durum-tamamlandi  { background: #d8f0df; color: #1c7a44; }
.durum-iptal       { background: #fadadd; color: #b5283a; }

/* ---------- Flash / toast ---------- */
.toast-kutu { position: fixed; right: 16px; bottom: 16px; z-index: 200; display: flex; flex-direction: column; gap: .6rem; max-width: calc(100vw - 32px); }
.toast {
  display: flex; align-items: center; gap: .7rem; padding: .85rem 1.1rem; border-radius: var(--radius-sm);
  background: #fff; box-shadow: var(--golge-lg); border-left: 4px solid var(--turuncu);
  animation: toastIn .3s ease; font-size: .92rem; font-weight: 500; min-width: 240px;
}
.toast.basari { border-left-color: var(--yesil); }
.toast.basari .ikon { color: var(--yesil); }
.toast.hata { border-left-color: var(--kirmizi); }
.toast.hata .ikon { color: var(--kirmizi); }
.toast.cikan { animation: toastOut .3s ease forwards; }
@keyframes toastIn { from { transform: translateX(120%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes toastOut { to { transform: translateX(120%); opacity: 0; } }

/* ---------- Footer ---------- */
.footer { background: var(--metin); color: #cabfb2; margin-top: 3.5rem; padding: 3rem 0 1.5rem; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; margin-bottom: 2rem; }
.footer h4 { color: #fff; font-size: 1rem; margin-bottom: 1rem; }
.footer-marka .logo { color: #fff; margin-bottom: .8rem; }
.footer-marka p { font-size: .9rem; max-width: 22rem; }
.footer a { display: block; padding: .3rem 0; color: #cabfb2; font-size: .92rem; transition: var(--gecis); }
.footer a:hover { color: var(--turuncu); padding-left: .25rem; }
.footer-iletisim div { display: flex; align-items: center; gap: .55rem; padding: .3rem 0; font-size: .9rem; }
.footer-alt { border-top: 1px solid rgba(255,255,255,.1); padding-top: 1.3rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: .85rem; }
.footer-alt a { display: inline; }

/* ---------- Breadcrumb ---------- */
.iz { display: flex; align-items: center; gap: .4rem; font-size: .85rem; color: var(--metin-acik); padding: 1.1rem 0; flex-wrap: wrap; }
.iz a:hover { color: var(--turuncu); }
.iz .ikon { width: 14px; height: 14px; }

/* ---------- Filtre çubuğu ---------- */
.filtre-bar { display: flex; gap: .6rem; flex-wrap: wrap; margin-bottom: 1.6rem; }
.filtre-cip {
  padding: .5rem 1rem; border-radius: 999px; background: #fff; border: 1px solid var(--cizgi);
  font-size: .88rem; font-weight: 500; transition: var(--gecis); color: var(--metin-acik);
}
.filtre-cip:hover { border-color: var(--turuncu); color: var(--turuncu); }
.filtre-cip.aktif { background: var(--turuncu); border-color: var(--turuncu); color: #fff; }

/* ---------- Görsel yer tutucu (emoji) ---------- */
.gorsel-ph { width: 100%; height: 100%; display: grid; place-items: center; font-size: 2.6rem; background: linear-gradient(135deg, var(--krem-koyu), #e9ddc9); }
.detay-ana-gorsel .gorsel-ph { font-size: 5rem; }
.sepet-gorsel .gorsel-ph, .urun-gorsel .gorsel-ph { font-size: 2rem; }

/* ==========================================================================
   Responsive — tablet & masaüstü
   ========================================================================== */
@media (min-width: 560px) {
  .urun-grid { grid-template-columns: repeat(3,1fr); }
  .kategori-grid { grid-template-columns: repeat(3,1fr); }
  .form-ikili { grid-template-columns: 1fr 1fr; }
  .hero-yazi h1 { font-size: 2.6rem; }
}

@media (min-width: 860px) {
  .nav-linkler { display: flex; }
  .menu-btn { display: none; }
  .hero-ic { grid-template-columns: 1.05fr .95fr; padding: 4rem 0 4.5rem; }
  .hero-yazi h1 { font-size: 3.1rem; }
  .urun-grid { grid-template-columns: repeat(4,1fr); }
  .kategori-grid { grid-template-columns: repeat(5,1fr); }
  .detay-grid { grid-template-columns: 1fr 1fr; gap: 3rem; }
  .sepet-duzen { grid-template-columns: 1fr 360px; align-items: start; }
  .checkout-duzen { grid-template-columns: 1.4fr 1fr; align-items: start; }
  .hesap-grid { grid-template-columns: 280px 1fr; align-items: start; }
  .footer-grid { grid-template-columns: 2fr 1fr 1fr 1.4fr; }
  .bolum { padding: 4rem 0; }
}

@media (min-width: 1024px) {
  .container { padding: 0 24px; }
}
