/* ==========================================
   KATMAN - ANA STİL DOSYASI
========================================== */

* { margin: 0; padding: 0; box-sizing: border-box; scrollbar-width: thin; scrollbar-color: #ff99cc #111; }
*::-webkit-scrollbar { width: calc(var(--y) * 0.25); }
*::-webkit-scrollbar-track { background: #111; border-radius: calc(var(--y) * 0.5); }
*::-webkit-scrollbar-thumb { background: #ff99cc; border-radius: calc(var(--y) * 0.5); }

/* ZEKÂ: Ana ekranın scroll'u kapatıldı, 100% yükseklik kilitlendi */
body { 
    background-color: #000; color: #fff; font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; 
    overflow: hidden; height: 100vh; width: 100vw; 
}

/* ZEKÂ: Sitenin ana iskeleti artık dikey (column) flex yapısına geçti */
.main-container { 
    display: flex; flex-direction: column; height: 100vh; width: 100%; 
}

/* ==========================================
   HAYALET SCROLLBAR (GÖRÜNMEZ -> GÖRÜNÜR)
========================================== */
.scrollable-area { 
    flex: 1; overflow-y: auto; overflow-x: hidden; width: 100%; 
    /* ZEKÂ: Masaüstünde sağda ve solda tam 1y boşluk bırakır. */
    padding: 0 calc(var(--y) * 1); 
}

/* Scrollbar varsayılan olarak şeffaf (Hayalet) */
.scrollable-area::-webkit-scrollbar { width: calc(var(--y) * 0.5); }
.scrollable-area::-webkit-scrollbar-track { background: transparent; }
.scrollable-area::-webkit-scrollbar-thumb { background: transparent; border-radius: calc(var(--y) * 0.25); }

/* JS ile '.is-scrolling' sınıfı eklendiğinde anında görünür olur */
.scrollable-area.is-scrolling::-webkit-scrollbar-thumb { background: #ff99cc; }
.scrollable-area.is-scrolling::-webkit-scrollbar-thumb:hover { background: #ff66aa; }

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

/* AÇILIŞ VE HEADER EKRANI */
#splash-screen { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background: #000; z-index: 9999; display: flex; align-items: center; justify-content: center; transition: opacity 0.8s ease-out; }
#splash-screen.hidden-splash { opacity: 0; pointer-events: none; }
.splash-content { text-align: center; }

/* ZEKÂ: Splash ekranındaki görsel logo için zarif boyutlandırma ve parlama (pulse) efekti */
.splash-logo { 
    height: calc(var(--y) * 8); /* Göz yormayan şık bir boyut */
    width: auto; 
    object-fit: contain; 
    filter: drop-shadow(0 0 calc(var(--y) * 1.5) rgba(255, 153, 204, 0.4));
    animation: pulseGlow 2s infinite alternate ease-in-out;
}

@keyframes pulseGlow {
    0% { filter: drop-shadow(0 0 calc(var(--y) * 0.5) rgba(255, 153, 204, 0.2)); transform: scale(1); }
    100% { filter: drop-shadow(0 0 calc(var(--y) * 2) rgba(255, 153, 204, 0.6)); transform: scale(1.02); }
}

/* GENEL BUTONLAR VE TOAST */
.main-container { padding-top: calc(var(--y) * 4); min-height: 100vh; padding-bottom: calc(var(--y) * 2.5); }
.action-btn { width: 100%; background: transparent; color: #ff99cc; font-weight: bold; padding: calc(var(--y) * 0.75); border: 2px solid #ff99cc; border-radius: calc(var(--y) * 0.25); cursor: pointer; font-size: calc(var(--y) * 1.1); text-transform: uppercase; transition: 0.2s; }
.action-btn:hover:not(.disabled) { background: #ff99cc; color: #fff; }
.action-btn.disabled { pointer-events: none; opacity: 0.5; }
.back-btn { display: inline-block; margin-bottom: calc(var(--y) * 1); color: #aaa; cursor: pointer; text-decoration: underline; font-weight: bold; }
.back-btn:hover { color: #ff99cc; }
.toast-notification { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: rgba(17, 17, 17, 0.9); border: 2px solid #ff99cc; color: #ff99cc; padding: calc(var(--y) * 1) calc(var(--y) * 2); border-radius: calc(var(--y) * 0.75); font-size: calc(var(--y) * 1.4); font-weight: bold; z-index: 10000; backdrop-filter: blur(calc(var(--y) * 0.5)); pointer-events: none; opacity: 0; transition: opacity 0.4s ease-in-out, transform 0.4s ease-out; box-shadow: 0 calc(var(--y) * 0.75) calc(var(--y) * 1.75) rgba(0,0,0,0.5); display: flex; align-items: center; gap: calc(var(--y) * 0.75); }
.toast-notification.show { opacity: 1; transform: translate(-50%, -55%); }

/* KATEGORİ BAŞLIĞI VE ALT KATEGORİ BARI */
.category-page-title { text-align: center; font-size: calc(var(--y) * 1.6); font-weight: bold; letter-spacing: 3px; color: #fff; margin: calc(var(--y) * 0.5) 0 calc(var(--y) * 1.25) 0; text-transform: uppercase; border-bottom: 1px dashed #333; padding-bottom: calc(var(--y) * 0.75); }
.sub-category-bar { display: flex; gap: calc(var(--y) * 0.5); overflow-x: auto; padding-bottom: calc(var(--y) * 0.75); margin-bottom: calc(var(--y) * 0.75); scrollbar-width: none; }
.sub-category-bar::-webkit-scrollbar { display: none; }
.sub-cat-btn { background: #111; border: 1px solid #ff99cc; color: #ff99cc; padding: calc(var(--y) * 0.5) calc(var(--y) * 1); border-radius: calc(var(--y) * 1); font-size: calc(var(--y) * 0.9); cursor: pointer; white-space: nowrap; transition: 0.2s; text-transform: uppercase; font-weight: bold; }
.sub-cat-btn:hover { background: #ff99cc; color: #000; }
.sub-cat-btn.active { background: #ff99cc; color: #000; border-color: #ff99cc; }

/* FİLTRE BARI */
#filter-bar { padding: calc(var(--y) * 0.5); max-width: calc(var(--y) * 70); margin: 0 auto; }
#filter-bar.hidden { display: none; }
.filter-dropdown-container { display: flex; gap: calc(var(--y) * 0.5); flex-wrap: wrap; margin-bottom: calc(var(--y) * 0.75); width: 100%; border-bottom: 1px dashed #333; padding-bottom: calc(var(--y) * 0.75); }
.filter-dropdown { position: relative; }
.filter-btn { background: #1a1a1a; color: #ff99cc; border: 1px solid #ff99cc; padding: calc(var(--y) * 0.5) calc(var(--y) * 1); border-radius: calc(var(--y) * 0.25); cursor: pointer; display: flex; align-items: center; gap: calc(var(--y) * 0.5); font-size: calc(var(--y) * 0.9); font-weight: bold; text-transform: uppercase; transition: 0.2s; }
.filter-btn:hover { background: #ff99cc; color: #000; }
.filter-content { display: none; position: absolute; top: 100%; left: 0; background: #111; min-width: calc(var(--y) * 10); border: 1px solid #ff99cc; border-radius: calc(var(--y) * 0.25); padding: calc(var(--y) * 0.75); z-index: 100; margin-top: calc(var(--y) * 0.5); box-shadow: 0 calc(var(--y) * 0.5) calc(var(--y) * 1.25) rgba(0,0,0,0.8); max-height: none !important; overflow-y: visible !important; }
.filter-content.show { display: flex; flex-direction: column; gap: calc(var(--y) * 0.5); }
.filter-content-label { display: flex; align-items: center; gap: calc(var(--y) * 0.5); cursor: pointer; font-size: calc(var(--y) * 0.9); color: #eee; text-transform: uppercase; }
.filter-content-label:hover { color: #ff99cc; }
.filter-checkbox { accent-color: #ff99cc; width: calc(var(--y) * 0.75); height: calc(var(--y) * 0.75); cursor: pointer; }
.active-filters-row { display: flex; flex-wrap: wrap; gap: calc(var(--y) * 0.5); margin-bottom: calc(var(--y) * 0.75); align-items: center; width: 100%; }
.filter-tag.active { background: #ff99cc; color: #000; border: none; font-weight: bold; padding: calc(var(--y) * 0.25) calc(var(--y) * 0.5); display: flex; align-items: center; gap: calc(var(--y) * 0.5); border-radius: calc(var(--y) * 1); cursor: pointer; }

/* ==========================================
   ANA KUTU SİSTEMİ VE KAYIP GRID KURALLARI
========================================== */

/* ZEKÂ: Max-width 1600px yapıldı ve justify-content: center ile sağdaki boşluk hatası çözüldü */
.katman-page-grid { 
    display: grid; grid-template-columns: repeat(4, 1fr); gap: calc(var(--y) * 0.5); 
    max-width: 1600px; margin: 0 auto; padding: calc(var(--y) * 0.5); 
    align-items: start; justify-content: center; 
}

.box-span-2 { grid-column: span 2; }

.grid-container {
    display: grid;
    row-gap: 0; 
    column-gap: var(--y);
    grid-auto-rows: var(--y);
    padding: calc(var(--y) * 0.5) 0;
    max-width: 1600px;
    margin: 0 auto;
    justify-content: center; /* ZEKÂ: 67 birimlik içeriği 69 birimlik alanın tam ortasına sabitler */
}

/* Kutuların Ana İskeleti */
.card { position: relative; background: #fff; border-radius: calc(var(--y) * 0.5); overflow: hidden; cursor: pointer; transition: transform 0.3s; display: flex; flex-direction: column; min-width: 0; }
.card:hover { transform: scale(0.98); }
.card-image { flex-grow: 1; position: relative; background: #222; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.card-image img { width: 100%; height: 100%; object-fit: cover; position: absolute; top: 0; left: 0; }

/* ==========================================
   2 DURUMLU LÜKS VİTRİN DÜZENİ (YAZI VE İKON)
========================================== */

/* Ana Kutu (Kategoriler de bunu kullanır, bu yüzden varsayılan flex ayarları eklendi) */
.card-info { 
    height: calc(var(--y) * 3); 
    background: #ff99cc; 
    display: flex; align-items: center; justify-content: space-between; 
    padding: 0 calc(var(--y) * 0.75); 
    color: #000; z-index: 2; 
    min-width: 0; box-sizing: border-box;
    font-weight: bold; font-size: calc(var(--y) * 0.9); /* Kategori isimleri için korundu */
}

/* 1. DURUM: ÜRÜNE GİT / YİNE DE EKLE Varsa (İsim boydan boya uzar, Fiyat ve Yazı alttadır) */
.card-info.layout-text { flex-direction: column; justify-content: center; align-items: flex-start; font-weight: normal; font-size: initial; }
.card-info.layout-text .p-name { width: 100%; margin-bottom: calc(var(--y) * 0.4); /* ZEKÂ: Boşluk artırıldı, denge sağlandı */ }
.card-info.layout-text .card-info-bottom { display: flex; justify-content: space-between; align-items: center; width: 100%; }

/* 2. DURUM: SEPET İKONU Varsa (İsim ikona çarpmadan kesilir, İkon sağda dikilir) */
.card-info.layout-icon { flex-direction: row; justify-content: space-between; align-items: center; font-weight: normal; font-size: initial; }
.card-info.layout-icon .product-details { display: flex; flex-direction: column; justify-content: center; min-width: 0; flex-grow: 1; margin-right: calc(var(--y) * 0.5); }
.card-info.layout-icon .p-name { width: 100%; margin-bottom: calc(var(--y) * 0.4); /* ZEKÂ: Boşluk artırıldı, denge sağlandı */ }

/* Ortak Yazı Kuralları */
.p-name { 
    font-size: calc(var(--y) * 0.85); /* ZEKÂ: Daha büyük font */
    font-weight: 600; /* ZEKÂ: Okunaklı, zarif bir kalınlık (bold kadar kaba değil) */
    text-transform: uppercase; 
    white-space: nowrap; 
    overflow: hidden; 
    text-overflow: ellipsis; 
    line-height: 1; 
}
.p-price { 
    font-size: calc(var(--y) * 0.85); 
    font-weight: normal; 
    line-height: 1; 
}

/* ZEKÂ: Buton yazılarının alt satıra inmesini KESİN OLARAK yasaklayan zırhlar */
.go-to-product-text { font-size: calc(var(--y) * 0.7); color: #000; font-weight: 900; display: flex; align-items: center; gap: calc(var(--y) * 0.25); text-transform: uppercase; white-space: nowrap !important; flex-shrink: 0; }
.wishlist-btn-grid { white-space: nowrap !important; flex-shrink: 0; }
.wishlist-btn-grid .btn-text::before { white-space: nowrap !important; }

/* Zarif Ürüne Git Metni ve Sepet Butonu */
.add-btn { background: #000; color: #fff; display: flex; align-items: center; justify-content: center; transition: 0.2s; }
.add-btn:hover { background: #fff; color: #000; border: 1px solid #000; }
.add-btn.disabled { border-radius: calc(var(--y) * 0.25); font-size: calc(var(--y) * 0.7); pointer-events: none; opacity: 0.7; }
.cart-add-only { width: calc(var(--y) * 1.75); height: calc(var(--y) * 1.75); border-radius: 50%; font-size: calc(var(--y) * 1.1); background: #000; color: #ff99cc; border: 1px solid #ff99cc; }
.cart-add-only:hover { background: #ff99cc; color: #000; border: 1px solid #000; transform: scale(1.1); }

/* ÜRÜN SLIDER VE KARE KUTULAR */
.product-image-box { background: #222; border-radius: calc(var(--y) * 0.75); padding: 0 !important; aspect-ratio: 1 / 1; overflow: hidden !important; position: relative; }
.product-slider { display: flex; width: 100%; height: 100%; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; scroll-behavior: smooth; }
.product-slider::-webkit-scrollbar { display: none; }
.product-slider img { flex: 0 0 100%; width: 100%; height: 100%; object-fit: cover; scroll-snap-align: start; scroll-snap-stop: always; }

/* Masaüstü Okları ve Güvenli Tıklama Alanı */
.slider-nav { position: absolute; top: 0; bottom: 0; width: 15%; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 5; opacity: 0; transition: opacity 0.3s; }
.product-image-box:hover .slider-nav { opacity: 1; }
.slider-nav.left { left: 0; }
.slider-nav.right { right: 0; }
.slider-nav i { background: rgba(0,0,0,0.4); color: #fff; width: calc(var(--y) * 1.75); height: calc(var(--y) * 1.75); display: flex; align-items: center; justify-content: center; border-radius: 50%; font-size: calc(var(--y) * 0.9); backdrop-filter: blur(calc(var(--y) * 0.25)); transition: 0.2s; }
.slider-nav:hover i { background: #ff99cc; color: #000; transform: scale(1.1); }

/* Noktalı Navigasyon (Dots) */
.slider-dots { position: absolute; bottom: calc(var(--y) * 0.75); left: 50%; transform: translateX(-50%); display: flex; gap: calc(var(--y) * 0.5); z-index: 5; background: rgba(0,0,0,0.3); padding: calc(var(--y) * 0.5) calc(var(--y) * 0.5); border-radius: calc(var(--y) * 1); backdrop-filter: blur(calc(var(--y) * 0.25)); }
.slider-dot { width: calc(var(--y) * 0.5); height: calc(var(--y) * 0.5); background: rgba(255, 255, 255, 0.4); border-radius: 50%; cursor: pointer; transition: all 0.3s; }
.slider-dot:hover { background: rgba(255, 255, 255, 0.8); }
.slider-dot.active { background: #ff99cc; transform: scale(1.2); box-shadow: 0 0 calc(var(--y) * 0.5) #ff99cc; }

.product-info-box { background: #111; border: 1px solid #333; border-radius: calc(var(--y) * 0.75); padding: calc(var(--y) * 2); aspect-ratio: 1 / 1; height: auto; display: flex; flex-direction: column; }
.var-group { margin: calc(var(--y) * 1) 0; }
.var-title { font-size: calc(var(--y) * 0.9); color: #aaa; margin-bottom: calc(var(--y) * 0.5); display: block; text-transform: uppercase; letter-spacing: 1px; }
.var-btn { background: #222; color: #fff; border: 1px solid #444; padding: calc(var(--y) * 0.5) calc(var(--y) * 1); margin: 0 calc(var(--y) * 0.5) calc(var(--y) * 0.5) 0; border-radius: calc(var(--y) * 0.25); cursor: pointer; transition: 0.2s; font-size: calc(var(--y) * 0.9); }
.var-btn:hover { border-color: #ff99cc; }
.var-btn.active { background: #ff99cc; color: #000; border-color: #ff99cc; font-weight: bold; }

/* SEPET SAYFASI */
.cart-items-box { background: #fff; border-radius: calc(var(--y) * 0.75); padding: calc(var(--y) * 1.5); height: auto; }
.cart-summary-box { background: #111; border: 1px solid #333; border-radius: calc(var(--y) * 0.75); padding: calc(var(--y) * 1.5); aspect-ratio: 1 / 1; position: sticky; top: calc(var(--y) * 5); z-index: 10; }
.cart-items-box h2 { color: #000; border-bottom: 2px solid #eee; padding-bottom: calc(var(--y) * 0.75); margin-bottom: calc(var(--y) * 1); }
.cart-item { display: flex; align-items: center; gap: calc(var(--y) * 0.75); margin-bottom: calc(var(--y) * 0.75); background: #fdfdfd; border: 1px solid #eee; padding: calc(var(--y) * 0.5); border-radius: calc(var(--y) * 0.5); cursor: pointer; transition: 0.2s; }
.cart-item:hover { border-color: #ff99cc; }
.cart-item img { width: calc(var(--y) * 4); height: calc(var(--y) * 4); object-fit: cover; background: #222; border-radius: calc(var(--y) * 0.25); padding: 0; }
.cart-item-info { flex-grow: 1; }
.cart-item-info h4 { color: #000; margin-bottom: calc(var(--y) * 0.25); font-size: calc(var(--y) * 1.1); }
.qty-control { display: inline-flex; align-items: center; background: #f5f5f5; border: 1px solid #ddd; border-radius: calc(var(--y) * 0.25); overflow: hidden; margin-top: calc(var(--y) * 0.25); margin-left: calc(var(--y) * 0.75); }
.qty-btn { background: #eee; color: #000; border: none; padding: calc(var(--y) * 0.25) calc(var(--y) * 0.75); cursor: pointer; font-weight: bold; font-size: calc(var(--y) * 1.1); transition: 0.2s; }
.qty-btn:hover { background: #ff99cc; }
.qty-val { padding: 0 calc(var(--y) * 0.75); font-weight: bold; font-size: calc(var(--y) * 0.9); min-width: calc(var(--y) * 2); text-align: center; color: #000; }
.remove-btn { background: transparent; color: #ff4d4d; border: 1px solid #ff4d4d; padding: calc(var(--y) * 0.5) calc(var(--y) * 0.75); border-radius: calc(var(--y) * 0.25); font-weight: bold; cursor: pointer; transition: 0.2s; }
.remove-btn:hover { background: #ff4d4d; color: #fff; }

/* FORMLAR VE SAYFALAR */
.auth-container, .checkout-container { max-width: calc(var(--y) * 25); margin: 0 auto; background: #111; padding: calc(var(--y) * 2); border-radius: calc(var(--y) * 0.5); border: 1px solid #333; }
.auth-container h2, .checkout-container h2 { color: #ff99cc; margin-bottom: calc(var(--y) * 1); border-bottom: 1px dashed #333; padding-bottom: calc(var(--y) * 0.5); }
.form-group { margin-bottom: calc(var(--y) * 1); }
.form-group label { display: block; margin-bottom: calc(var(--y) * 0.5); color: #aaa; font-size: calc(var(--y) * 0.9); }
.form-group input { width: 100%; padding: calc(var(--y) * 0.5); background: #222; border: 1px solid #444; color: #fff; border-radius: calc(var(--y) * 0.25); }
.form-group input:focus { outline: none; border-color: #ff99cc; }

/* ZEKÂ: Tarayıcıların zorunlu tuttuğu Autofill beyazlığını içeriden koyu gölgeyle ezer */
input:-webkit-autofill,
input:-webkit-autofill:hover, 
input:-webkit-autofill:focus, 
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 calc(var(--y) * 2.5) #222 inset !important;
    -webkit-text-fill-color: #fff !important;
    transition: background-color 5000s ease-in-out 0s;
}

/* YENİ: Auth Sayfası Özel Stilleri (Şifre Unuttum, Uyarılar, Google Kapsayıcı) */
.google-auth-wrapper { min-height: calc(var(--y) * 2); display: flex; justify-content: center; align-items: center; margin-bottom: calc(var(--y) * 0.75); width: 100%; }
.forgot-pass-link { display: block; text-align: right; color: #888; font-size: calc(var(--y) * 0.9); margin-top: calc(var(--y) * 0.5); text-decoration: underline; cursor: pointer; transition: 0.2s; }
.forgot-pass-link:hover { color: #ff99cc; }
.input-warning { color: #ffcc00; font-size: calc(var(--y) * 0.7); margin-top: calc(var(--y) * 0.5); display: none; font-weight: bold; }
.input-warning.show { display: block; animation: fadeIn 0.3s; }
.form-checkbox-label { display:flex; align-items:flex-start; gap:calc(var(--y) * 0.5); cursor:pointer; color:#ccc; font-size:calc(var(--y) * 0.9); margin-bottom:calc(var(--y) * 0.5); line-height:1.4; }
.form-checkbox-label a { color:#ff99cc; text-decoration:underline; }

/* Ana Sayfa Grid İçin Küçük İstek Listesi Butonu */
.wishlist-btn-grid { display: flex; align-items: center; gap: calc(var(--y) * 0.25); cursor: pointer; }
.wishlist-btn-grid .btn-text::before { content: "TÜKENDİ"; }

/* Kart Hover Zekası (Tüm karta gelindiğinde resmi canlandır ve yazıyı değiştir) */
.out-of-stock-img { filter: grayscale(100%) opacity(0.7); transition: 0.4s ease; }
.card:hover .out-of-stock-img { filter: grayscale(0%) opacity(1); }
.card:hover .wishlist-btn-grid .btn-text::before { content: "YİNE DE EKLE"; }

/* SEPET KUTUCUKLARI (LÜKS TASARIM) */
.cart-checkbox {
    width: calc(var(--y) * 1.25); height: calc(var(--y) * 1.25); border: 2px solid #ff99cc; border-radius: calc(var(--y) * 0.25);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; margin-right: calc(var(--y) * 0.75); transition: 0.2s; flex-shrink: 0;
}
.cart-checkbox.active { background: #ff99cc; }
.cart-checkbox.active::after { content: '\f00c'; font-family: 'Font Awesome 6 Free'; font-weight: 900; color: #000; font-size: calc(var(--y) * 0.9); }
.cart-checkbox.disabled { border-color: #444; cursor: not-allowed; background: transparent; }

/* ==========================================
   KULLANICI PANELİ (DASHBOARD) TASARIMI
========================================== */
.dashboard-container { display: flex; width: 100%; justify-content: center; gap: calc(var(--y) * 1); padding: calc(var(--y) * 1) 0; align-items: flex-start; }
.dashboard-sidebar { width: calc(var(--y) * 18); flex-shrink: 0; background: #111; border: 1px solid #333; border-radius: calc(var(--y) * 0.5); padding: calc(var(--y) * 1) 0; position: sticky; }
.dashboard-user-info { text-align: center; padding: 0 calc(var(--y) * 1) calc(var(--y) * 1) calc(var(--y) * 1); border-bottom: 1px dashed #333; margin-bottom: calc(var(--y) * 0.5); }
.dashboard-user-info h3 { color: #ff99cc; margin-bottom: calc(var(--y) * 0.25); font-size: calc(var(--y) * 1.1); }
.dashboard-user-info p { color: #aaa; font-size: calc(var(--y) * 0.9); }
.dashboard-menu { display: flex; flex-direction: column; }
.dash-menu-btn { background: transparent; color: #fff; text-align: left; padding: calc(var(--y) * 0.75) calc(var(--y) * 1.25); border: none; border-left: 3px solid transparent; cursor: pointer; transition: 0.2s; font-size: calc(var(--y) * 0.9); display: flex; align-items: center; gap: calc(var(--y) * 0.75); }
.dash-menu-btn:hover { background: #222; color: #ff99cc; }
.dash-menu-btn.active { background: #1a1a1a; color: #ff99cc; border-left-color: #ff99cc; font-weight: bold; }
.dashboard-content { width: calc(var(--y) * 48); flex-shrink: 0; background: #111; border: 1px solid #333; border-radius: calc(var(--y) * 0.5); padding: calc(var(--y) * 1.5); min-height: calc(var(--y) * 25); }

/* Cüzdan Kartı Özel Tasarımı */
.wallet-card { background: linear-gradient(135deg, #222, #000); border: 1px solid #ff99cc; border-radius: calc(var(--y) * 0.75); padding: calc(var(--y) * 1.5); text-align: center; position: relative; overflow: hidden; }
.wallet-card::before { content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%; background: radial-gradient(circle, rgba(255,153,204,0.1) 0%, transparent 70%); }
.wallet-balance { font-size: calc(var(--y) * 3); color: #ff99cc; font-weight: bold; margin: calc(var(--y) * 0.75) 0; text-shadow: 0 0 calc(var(--y) * 0.75) rgba(255,153,204,0.3); }

/* Mobil Dashboard Başlığı (Geniş Ekranda Gizli) */
.mobile-dash-header { display: none; }

/* SİPARİŞ GEÇMİŞİ KARTLARI */
.order-card { background: #1a1a1a; border: 1px solid #333; border-radius: calc(var(--y) * 0.5); padding: calc(var(--y) * 1); margin-bottom: calc(var(--y) * 1); transition: 0.2s; }
.order-card:hover { border-color: #555; background: #222; }
.order-header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px dashed #444; padding-bottom: calc(var(--y) * 0.75); margin-bottom: calc(var(--y) * 0.75); font-size: calc(var(--y) * 0.9); color: #aaa; }
.order-no { color: #fff; font-weight: bold; font-family: monospace; font-size: calc(var(--y) * 1.1); letter-spacing: 1px; }
.order-status { padding: calc(var(--y) * 0.25) calc(var(--y) * 0.5); border-radius: calc(var(--y) * 1); font-size: calc(var(--y) * 0.7); font-weight: bold; text-transform: uppercase; }
.status-yeni { background: rgba(255, 153, 204, 0.15); color: #ff99cc; border: 1px solid #ff99cc; }
.status-kargoda { background: rgba(74, 222, 128, 0.15); color: #4ade80; border: 1px solid #4ade80; }
.order-items-preview { display: flex; gap: calc(var(--y) * 0.5); margin-bottom: calc(var(--y) * 0.75); overflow-x: auto; padding-bottom: calc(var(--y) * 0.25); }
.order-item-img { width: calc(var(--y) * 3); height: calc(var(--y) * 3); border-radius: calc(var(--y) * 0.25); object-fit: cover; border: 1px solid #333; flex-shrink: 0; }
.order-footer { display: flex; justify-content: space-between; align-items: center; padding-top: calc(var(--y) * 0.5); }
.order-total { font-size: calc(var(--y) * 1.1); font-weight: bold; color: #fff; }
.wallet-badge { font-size: calc(var(--y) * 0.7); color: #ff99cc; background: rgba(255,153,204,0.1); padding: calc(var(--y) * 0.15) calc(var(--y) * 0.5); border-radius: calc(var(--y) * 0.25); margin-left: calc(var(--y) * 0.5); }

/* ÜRÜN SAYFASI - NOT, FAVORİ VE TABLAR */
.product-note { font-size: calc(var(--y) * 0.9); color: #aaa; background: #1a1a1a; padding: calc(var(--y) * 0.5) calc(var(--y) * 0.75); border-left: 3px solid #ff99cc; margin: calc(var(--y) * 0.5) 0 calc(var(--y) * 1) 0; font-style: italic; border-radius: 0 calc(var(--y) * 0.25) calc(var(--y) * 0.25) 0; }
.fav-btn { position: absolute; top: calc(var(--y) * 1); right: calc(var(--y) * 1); background: rgba(0,0,0,0.5); color: #fff; width: calc(var(--y) * 2.25); height: calc(var(--y) * 2.25); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: calc(var(--y) * 1.4); cursor: pointer; z-index: 10; backdrop-filter: blur(calc(var(--y) * 0.25)); border: 1px solid #333; transition: 0.3s; }
.fav-btn:hover { background: #111; color: #ff99cc; border-color: #ff99cc; transform: scale(1.1); }
.fav-btn.active { color: #ff99cc; }
.fav-btn.active .fa-heart { font-weight: 900; }

/* WIDE / NARROW MOD ÜRÜN KUTULARI (DİKEY ESNEKLİK VE KUSURSUZ HİZALAMA) */
.box-span-full { grid-column: 1 / -1; width: 100%; min-width: 0; }

/* Sekme Butonları (Mobil İçin Ortak) */
.prod-tab-btn { background: transparent; color: #888; border: none; padding: calc(var(--y) * 0.25) 0 calc(var(--y) * 0.5) 0; font-size: calc(var(--y) * 1.1); font-weight: bold; cursor: pointer; text-transform: uppercase; transition: 0.2s; position: relative; }
.prod-tab-btn:hover { color: #ff99cc; }
.prod-tab-btn.active { color: #ff99cc; }
.prod-tab-btn.active::after { content: ''; position: absolute; bottom: -1px; left: 0; width: 100%; height: 2px; background: #ff99cc; }

/* Yorum Listesi Tasarımı */
.customer-review { border-bottom: 1px dashed #333; padding-bottom: calc(var(--y) * 0.75); margin-bottom: calc(var(--y) * 0.75); }
.customer-review:last-child { border-bottom: none; }
.cr-header { display: flex; justify-content: space-between; margin-bottom: calc(var(--y) * 0.25); font-size: calc(var(--y) * 0.9); }
.cr-name { font-weight: bold; color: #fff; }
.cr-date { color: #666; }
.cr-stars { color: #ffcc00; font-size: calc(var(--y) * 0.9); margin-bottom: calc(var(--y) * 0.5); }
.cr-text { color: #ccc; font-size: calc(var(--y) * 0.9); line-height: 1.6; }

/* ZEKÂ: Sadece Yorum Yokken 'Giriş Yap' Kutusunu ve Metnini Dikey Ortala */
#tab-reviews:not(:has(.customer-review)) > div:nth-of-type(1) { margin-top: auto; }
#tab-reviews:not(:has(.customer-review)) > #prod-reviews-container { margin-bottom: auto; }

/* SİPARİŞ TAKİP ZAMAN ÇİZELGESİ (TIMELINE) */
.tracking-timeline { display: flex; align-items: center; justify-content: space-between; margin: calc(var(--y) * 1) 0; }
.tl-step { display: flex; flex-direction: column; align-items: center; position: relative; z-index: 2; width: 30%; }
.tl-icon { width: calc(var(--y) * 2.5); height: calc(var(--y) * 2.5); border-radius: 50%; background: #222; border: 2px solid #444; display: flex; align-items: center; justify-content: center; color: #666; font-size: calc(var(--y) * 1.1); margin-bottom: calc(var(--y) * 0.5); transition: 0.3s; }
.tl-text { color: #666; font-size: calc(var(--y) * 0.9); font-weight: bold; text-align: center; text-transform: uppercase; }
.tl-line { flex-grow: 1; height: calc(var(--y) * 0.25); background: #333; position: relative; z-index: 1; transform: translateY(-calc(var(--y) * 0.75)); }

/* Aktif (Tamamlanmış) Adımlar */
.tl-step.active .tl-icon { background: rgba(255, 153, 204, 0.1); border-color: #ff99cc; color: #ff99cc; box-shadow: 0 0 calc(var(--y) * 0.75) rgba(255, 153, 204, 0.2); }
.tl-step.active .tl-text { color: #fff; }
.tl-line.active { background: #ff99cc; }

/* ==========================================
   YENİ: BÖLÜNMÜŞ GİRİŞ / KARŞILAMA EKRANI (SPLIT AUTH)
========================================== */
.split-auth-wrapper { display: flex; gap: calc(var(--y) * 1); max-width: calc(var(--y) * 45); margin: calc(var(--y) * 2) auto; padding: 0 calc(var(--y) * 1); }
.split-auth-box { flex: 1; background: #111; border: 1px solid #333; border-radius: calc(var(--y) * 0.75); padding: calc(var(--y) * 2); text-align: center; transition: transform 0.3s, border-color 0.3s; display: flex; flex-direction: column; justify-content: flex-start; }
.split-auth-box:hover { transform: translateY(-calc(var(--y) * 0.25)); border-color: #ff99cc; }
.split-auth-icon { font-size: calc(var(--y) * 3); color: #ff99cc; margin-bottom: calc(var(--y) * 1); text-shadow: 0 0 calc(var(--y) * 0.75) rgba(255, 153, 204, 0.3); }
.split-auth-title { font-size: calc(var(--y) * 1.4); color: #fff; margin-bottom: calc(var(--y) * 0.75); text-transform: uppercase; letter-spacing: 2px; }
.split-auth-desc { color: #aaa; font-size: calc(var(--y) * 0.9); margin-bottom: calc(var(--y) * 1.75); line-height: 1.6; }

/* ==========================================
   BİLET (TICKET) GÖRSEL SİPARİŞ SEÇİCİ
========================================== */
.ticket-order-card { background: #222; border: 1px solid #333; border-radius: calc(var(--y) * 0.5); padding: calc(var(--y) * 0.75); cursor: pointer; transition: 0.2s; }
.ticket-order-card:hover { border-color: #ff99cc; }
.ticket-order-card.selected { border-color: #ff99cc; background: rgba(255,153,204,0.1); }
.ticket-order-header { color: #aaa; font-size: calc(var(--y) * 0.9); margin-bottom: calc(var(--y) * 0.5); display: flex; justify-content: space-between; align-items: center; }
.ticket-order-header strong { color: #fff; font-family: monospace; font-size: calc(var(--y) * 1.1); }
.ticket-order-items { display: flex; gap: calc(var(--y) * 0.5); overflow-x: auto; padding-bottom: calc(var(--y) * 0.25); scrollbar-width: none; }
.ticket-order-items::-webkit-scrollbar { display: none; }
.ticket-order-item { display: flex; flex-direction: column; gap: calc(var(--y) * 0.25); width: calc(var(--y) * 3); flex-shrink: 0; align-items: center; }
.ticket-order-item img { width: calc(var(--y) * 3); height: calc(var(--y) * 3); object-fit: cover; border-radius: calc(var(--y) * 0.25); border: 1px solid #444; transition: transform 0.3s ease; }
.ticket-order-item:hover img { transform: scale(1.2); z-index: 10; position: relative; border-color: #ff99cc; }
.ticket-order-item-name { font-size: calc(var(--y) * 0.7); color: #888; text-align: center; width: 100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ==========================================
   ORTAK PROFİL MENÜSÜ (DASHBOARD KÖK DİZİNİ)
========================================== */
/* ZEKÂ: Wide Mod - Ortadaki 2 gridin kapladığı alan kadar (Max calc(var(--y) * 35)) büyür ve ortalanır */
.common-profile-wrapper { display: flex; justify-content: center; align-items: center; padding: calc(var(--y) * 2) 0; min-height: 60vh; width: 100%; }
.common-profile-box { width: 100%; max-width: calc(var(--y) * 33); background: #111; border: 1px solid #333; border-radius: calc(var(--y) * 0.5); overflow: hidden; box-shadow: 0 calc(var(--y) * 0.5) calc(var(--y) * 1.5) rgba(0,0,0,0.5); animation: fadeIn 0.3s ease; }

/* ==========================================
   KVKK MODAL VE İÇ SAYFA GÜVENLİK PANELLERİ
========================================== */
.kvkk-modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.85); z-index: 99999; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: 0.3s ease; backdrop-filter: blur(calc(var(--y) * 0.25)); }
.kvkk-modal-overlay.active { opacity: 1; pointer-events: all; }
.kvkk-modal-content { background: #111; border: 1px solid #ff99cc; width: 95%; max-width: calc(var(--y) * 40); max-height: 90vh; border-radius: calc(var(--y) * 0.5); display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 calc(var(--y) * 0.5) calc(var(--y) * 2) rgba(255,153,204,0.15); transform: translateY(calc(var(--y) * 1)); transition: 0.3s ease; }
.kvkk-modal-overlay.active .kvkk-modal-content { transform: translateY(0); }
.kvkk-modal-body { padding: calc(var(--y) * 1.5); overflow-y: auto; flex-grow: 1; }
.kvkk-modal-footer { padding: calc(var(--y) * 1); background: #1a1a1a; border-top: 1px dashed #333; display: flex; justify-content: flex-end; gap: calc(var(--y) * 0.75); }

/* Granüler (Satır Satır) Düzenleme Paneli */
.inline-edit-row { display: flex; align-items: center; gap: calc(var(--y) * 0.75); margin-bottom: calc(var(--y) * 0.75); padding-bottom: calc(var(--y) * 0.75); transition: 0.3s; }
.inline-edit-row label { width: calc(var(--y) * 5); color: #888; font-size: calc(var(--y) * 0.9); margin: 0; flex-shrink: 0; }
.inline-edit-row input, .inline-edit-row select { flex-grow: 1; background: #1a1a1a; border: 1px solid #333; color: #ccc; padding: calc(var(--y) * 0.5); border-radius: calc(var(--y) * 0.25); transition: 0.3s; font-weight: bold; }
.inline-edit-row input:not(:disabled), .inline-edit-row select:not(:disabled) { background: #222; border-color: #ff99cc; box-shadow: 0 0 calc(var(--y) * 0.5) rgba(255,153,204,0.1); color: #fff; }
.inline-edit-row input:focus:not(:disabled), .inline-edit-row select:focus:not(:disabled) { outline: none; border-color: #ff99cc; }

/* ZEKÂ: UI Kilitlendiğinde Pasif Kalan Butonlar */
.ui-locked { opacity: 0.3; pointer-events: none; filter: grayscale(100%); }

/* ZEKÂ: Yeni E-Posta kutucuğunun varsayılan pembe konturunu ezme (Sadece odaklanınca pembe olur) */
#new-email-input:not(:focus) { background: #1a1a1a !important; border-color: #333 !important; box-shadow: none !important; color: #ccc !important; }
#new-email-input:focus { background: #222 !important; border-color: #ff99cc !important; color: #fff !important; }

.inline-edit-actions { width: calc(var(--y) * 7); text-align: right; flex-shrink: 0; }

/* Lüks Profil Butonları ve Hover Zekâsı (Zarif Boyut) */
.btn-profile-pink { background: transparent; color: #ff99cc; border: 1px solid #ff99cc; padding: calc(var(--y) * 0.25) calc(var(--y) * 0.5); border-radius: calc(var(--y) * 0.25); font-weight: bold; cursor: pointer; transition: 0.3s; text-transform: uppercase; display: inline-block; text-align: center; font-size: calc(var(--y) * 0.7); }
.btn-profile-pink:hover { background: #ff99cc; color: #fff; }
.btn-profile-pink:disabled { opacity: 0.5; cursor: not-allowed; border-color: #444; color: #555; }

/* ZEKÂ: Dev SİL butonu küçültüldü ve diğerlerine hizalandı */
.btn-profile-red { background: transparent; color: #ff4d4d; border: 1px solid #ff4d4d; padding: calc(var(--y) * 0.25) calc(var(--y) * 0.5); border-radius: calc(var(--y) * 0.25); font-weight: bold; cursor: pointer; transition: 0.3s; text-transform: uppercase; display: inline-block; text-align: center; font-size: calc(var(--y) * 0.7); }
.btn-profile-red:hover { background: #ff4d4d; color: #000; }

/* ZEKÂ: Dinamik İPTAL ve ONAYLA butonları */
.btn-profile-gray { background: transparent; color: #888; border: 1px solid #555; padding: calc(var(--y) * 0.25) calc(var(--y) * 0.5); border-radius: calc(var(--y) * 0.25); font-weight: bold; cursor: pointer; transition: 0.3s; text-transform: uppercase; display: inline-block; text-align: center; font-size: calc(var(--y) * 0.7); }
.btn-profile-gray:hover { background: #333; color: #fff; }

.btn-profile-green { background: transparent; color: #4ade80; border: 1px solid #4ade80; padding: calc(var(--y) * 0.25) calc(var(--y) * 0.5); border-radius: calc(var(--y) * 0.25); font-weight: bold; cursor: pointer; transition: 0.3s; text-transform: uppercase; display: inline-block; text-align: center; font-size: calc(var(--y) * 0.7); }
.btn-profile-green:hover { background: #4ade80; color: #000; }