/**
 * NECOX — Dark Mode + WCAG 2.1 AA (v3.28.0)
 *
 * Strateji:
 *   - CSS variable bazli renk sistemini `.dark-mode` selector'unda geri tanimla
 *   - Beyaz arkaplan, siyah yazi → koyu arkaplan, acik yazi
 *   - Kart, modal, input, dropdown arka planlari koyulastir
 *   - Odak halkalari WCAG icin 3px + 3:1 kontrast
 *   - Skip link, ARIA, motion-reduce destegi
 */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DARK MODE — ROOT DEGISKENLERI
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

:root.dark-mode {
    color-scheme: dark;

    /* Temel yuzeyler */
    --t-bg:         #0f172a;     /* body */
    --t-surface:    #1e293b;     /* kart */
    --t-surface-2:  #334155;     /* hover */
    --t-muted:      #334155;     /* alt panel */
    --t-border:     #334155;
    --t-border-light: #475569;

    /* Metin */
    --t-text:        #f1f5f9;
    --t-text-muted:  #94a3b8;
    --t-text-soft:   #cbd5e1;
    --t-heading:     #f8fafc;

    /* Aksiyon */
    --t-link:        #60a5fa;
    --t-link-hover:  #93c5fd;

    /* Durum */
    --t-success:     #34d399;
    --t-warning:     #fbbf24;
    --t-error:       #f87171;
    --t-info:        #60a5fa;

    /* Necox degiskenleri */
    --necox-bg:           #0f172a;
    --necox-fg:           #f1f5f9;
    --necox-white:        #1e293b;       /* v3.50.3 — kart/panel yuzeyi (80 yerde kullaniliyor) */
    --necox-text:         #f1f5f9;       /* v3.50.3 */
    --necox-heading:      #f8fafc;       /* v3.50.3 */
    --necox-muted:        #94a3b8;
    --necox-border:       #334155;
    --necox-card-bg:      #1e293b;
    --necox-card-hover-bg: #334155;      /* v3.50.3 */
    --necox-input-bg:     #1e293b;
    --necox-input-border: #475569;
    --necox-footer-text:  #94a3b8;       /* v3.50.3 */
    --necox-overlay:      rgba(0,0,0,0.75); /* v3.50.3 — daha koyu */
    --necox-shadow:       0 4px 6px rgba(0,0,0,0.4);
    --necox-shadow-sm:    0 1px 3px rgba(0,0,0,0.5);     /* v3.50.3 */
    --necox-shadow-lg:    0 10px 24px rgba(0,0,0,0.7);   /* v3.50.3 */
    --necox-shadow-hover: 0 14px 32px rgba(0,0,0,0.6);   /* v3.50.3 */
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DARK MODE — GENEL UYGULAMA
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.dark-mode body {
    background: var(--t-bg);
    color: var(--t-text);
}

/* Kart ve benzeri yuzeyler */
.dark-mode .necox-card,
.dark-mode .necox-dash-card,
.dark-mode .necox-dash-stat,
.dark-mode .necox-post-ad__auction-wrap,
.dark-mode .necox-auction-box,
.dark-mode .necox-dash-notifs__item,
.dark-mode .necox-dash-auction-card,
.dark-mode .necox-bell__panel,
.dark-mode .necox-lang-switcher__menu,
.dark-mode .necox-auction-pay-modal__inner {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-dash-card__title,
.dark-mode .necox-dash-auction-card__title,
.dark-mode .necox-dash-notifs__item-title,
.dark-mode .necox-bell__header h4,
.dark-mode h1,
.dark-mode h2,
.dark-mode h3,
.dark-mode h4 {
    color: var(--t-heading);
}

.dark-mode .necox-dash-stat__label,
.dark-mode .necox-dash-auction-card__meta,
.dark-mode .necox-dash-notifs__item-text,
.dark-mode .necox-dash-notifs__item-meta {
    color: var(--t-text-muted);
}

/* Header/Footer presetlerinin dark state'leri mevcut -> genisletmeyelim */

/* Inputlar */
.dark-mode input[type="text"],
.dark-mode input[type="email"],
.dark-mode input[type="password"],
.dark-mode input[type="number"],
.dark-mode input[type="url"],
.dark-mode input[type="search"],
.dark-mode textarea,
.dark-mode select,
.dark-mode .necox-post-ad__input,
.dark-mode .necox-post-ad__select,
.dark-mode .necox-auction-bid-input,
.dark-mode .necox-auction-proxy-input {
    background: var(--necox-input-bg);
    color: var(--t-text);
    border-color: var(--necox-input-border);
}

.dark-mode input::placeholder,
.dark-mode textarea::placeholder {
    color: var(--t-text-muted);
    opacity: 0.7;
}

/* Linkler */
.dark-mode a {
    color: var(--t-link);
}

.dark-mode a:hover {
    color: var(--t-link-hover);
}

/* Dashboard sidebar */
.dark-mode .necox-dashboard__sidebar,
.dark-mode .necox-dashboard__sidebar-inner {
    background: var(--t-surface);
    border-color: var(--t-border);
}

.dark-mode .necox-dashboard__menu-item {
    color: var(--t-text-soft);
}

.dark-mode .necox-dashboard__menu-item:hover {
    background: var(--t-surface-2);
    color: var(--t-heading);
}

.dark-mode .necox-dashboard__menu-item.is-active {
    background: rgba(96, 165, 250, 0.15);
    color: var(--t-link);
}

/* Tab chipleri */
.dark-mode .necox-dash-auctions__tab,
.dark-mode .necox-dash-notifs__tab {
    background: var(--t-surface);
    border-color: var(--t-border);
    color: var(--t-text-soft);
}

.dark-mode .necox-dash-auctions__tab:hover,
.dark-mode .necox-dash-notifs__tab:hover {
    background: var(--t-surface-2);
    color: var(--t-heading);
}

/* Pills/badges */
.dark-mode .necox-dash-auction-card__pill {
    background: var(--t-muted);
    color: var(--t-text-soft);
}

/* Notification bell — dark mode */
.dark-mode .necox-bell__header,
.dark-mode .necox-bell__footer {
    background: var(--t-surface-2);
    border-color: var(--t-border);
}

.dark-mode .necox-bell__item {
    border-color: var(--t-border);
}

.dark-mode .necox-bell__item:hover {
    background: var(--t-surface-2);
}

.dark-mode .necox-bell__item.is-unread {
    background: rgba(96, 165, 250, 0.1);
}

/* Toggle switches */
.dark-mode .necox-dash-notifs__switch span {
    background: var(--t-surface-2);
}

/* Tablolar */
.dark-mode table {
    color: var(--t-text);
}

.dark-mode th,
.dark-mode td {
    border-color: var(--t-border);
}

/* Scrollbar */
.dark-mode ::-webkit-scrollbar-track { background: var(--t-bg); }
.dark-mode ::-webkit-scrollbar-thumb { background: #475569; }
.dark-mode ::-webkit-scrollbar-thumb:hover { background: #64748b; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WCAG 2.1 AA — ODAKLANMA HALKALARI
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[tabindex]:focus-visible,
[role="button"]:focus-visible {
    outline: 3px solid #0284c7;
    outline-offset: 2px;
    border-radius: 4px;
}

.dark-mode a:focus-visible,
.dark-mode button:focus-visible,
.dark-mode input:focus-visible,
.dark-mode textarea:focus-visible,
.dark-mode select:focus-visible,
.dark-mode [tabindex]:focus-visible,
.dark-mode [role="button"]:focus-visible {
    outline-color: #60a5fa;
}

/* Fareyle tiklayinca odak halkasini gosterme (focus-visible zaten klavye odaklanmasi) */
button:focus:not(:focus-visible),
a:focus:not(:focus-visible) {
    outline: none;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WCAG — SKIP LINK (ekran okuyucu + klavye)
   Normal durumda: 1px x 1px, ekran disinda, opacity 0
   Focus oldugunda: sol ustte mavi buton olarak belirir
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.necox-skip-link {
    position: fixed !important;
    top: -9999px !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    opacity: 0 !important;
    pointer-events: none !important;
    background: #0284c7;
    color: #fff;
    padding: 8px 16px;
    z-index: 100000;
    text-decoration: none;
    font-weight: 600;
    border-bottom-right-radius: 4px;
}

.necox-skip-link:focus,
.necox-skip-link:focus-visible {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    clip: auto !important;
    clip-path: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    outline: 3px solid #0c4a6e;
    outline-offset: 2px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WCAG — SR-ONLY (sadece ekran okuyucu)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

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

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WCAG — REDUCED MOTION
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WCAG — YUKSEK KONTRAST MODU (Windows HCM)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

@media (forced-colors: active) {
    .necox-btn,
    .necox-dash-auction-card__pay-btn,
    .necox-auction-pay-btn,
    button[class*="necox"] {
        border: 1px solid CanvasText;
    }
    a:focus-visible,
    button:focus-visible {
        outline: 2px solid Highlight;
    }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DARK MODE TOGGLE BUTONU — MODE GOSTERGESI
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.necox-hf-darkmode {
    position: relative;
}

.necox-hf-darkmode[data-mode="auto"]::after {
    content: "A";
    position: absolute;
    bottom: 2px;
    right: 2px;
    font-size: 8px;
    font-weight: 700;
    color: #fff;
    background: #0284c7;
    border-radius: 50%;
    width: 12px;
    height: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   v3.50.3 — COMPONENT OVERRIDE'LARI
   Token seviyesinde cozulmeyen (hardcoded rgba/hex) kurallari normallestir.
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* --- AD CARD --- */
.dark-mode .necox-ad-card,
.dark-mode .necox-ad-card__body {
    background: var(--necox-card-bg);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-ad-card__favorite,
.dark-mode .necox-ad-card__sp-btn {
    background: rgba(30,41,59,0.85);
    color: var(--t-text);
}

.dark-mode .necox-ad-card__favorite:hover,
.dark-mode .necox-ad-card__sp-btn:hover {
    background: rgba(51,65,85,0.92);
    color: var(--t-heading);
}

.dark-mode .necox-ad-card__title,
.dark-mode .necox-ad-card__price {
    color: var(--t-heading);
}

.dark-mode .necox-ad-card__meta,
.dark-mode .necox-ad-card__loc,
.dark-mode .necox-ad-card__date,
.dark-mode .necox-ad-card__cat {
    color: var(--t-text-muted);
}

/* Kart uzeri koyu overlay gradient (resim alt gradient) — dark mode'da biraz daha yumusak */
.dark-mode .necox-ad-card__overlay-gradient {
    background: linear-gradient(transparent, rgba(0,0,0,0.85));
}

/* --- SINGLE ADVERT --- */
.dark-mode .necox-single-ad,
.dark-mode .necox-sad__main,
.dark-mode .necox-sad__sidebar,
.dark-mode .necox-sad__panel,
.dark-mode .necox-sad__section,
.dark-mode .necox-sad__cf-grid,
.dark-mode .necox-sad__desc,
.dark-mode .necox-sad__related,
.dark-mode .necox-sad__sticky-bar {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-sad__title,
.dark-mode .necox-sad__price,
.dark-mode .necox-sad__section-title {
    color: var(--t-heading);
}

.dark-mode .necox-sad__meta,
.dark-mode .necox-sad__breadcrumb,
.dark-mode .necox-sad__cf-label {
    color: var(--t-text-muted);
}

.dark-mode .necox-sad__cf-row {
    border-color: var(--t-border);
}

.dark-mode .necox-sad__share-btn {
    background: var(--t-surface-2);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- SELLER CARD / PUBLIC PROFILE / SELLERS --- */
.dark-mode .necox-seller-card,
.dark-mode .necox-profile-card,
.dark-mode .necox-profile-hero,
.dark-mode .necox-profile-stats,
.dark-mode .necox-sellers__item,
.dark-mode .necox-sellers__filter {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-seller-card__name,
.dark-mode .necox-profile-card__name,
.dark-mode .necox-sellers__item-name {
    color: var(--t-heading);
}

.dark-mode .necox-seller-card__meta,
.dark-mode .necox-profile-card__meta,
.dark-mode .necox-sellers__item-meta {
    color: var(--t-text-muted);
}

/* --- SEARCH RESULTS --- */
.dark-mode .necox-search-results,
.dark-mode .necox-search-results__panel,
.dark-mode .necox-search-results__tabs {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-search-results__tab {
    color: var(--t-text-soft);
}

.dark-mode .necox-search-results__tab.is-active {
    color: var(--t-link);
    border-color: var(--t-link);
}

/* --- ADV SEARCH (dropdown panel) --- */
.dark-mode .necox-adv-search__dropdown,
.dark-mode .necox-adv-search__panel,
.dark-mode .necox-search-panel {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-adv-search__option:hover,
.dark-mode .necox-search-panel__item:hover {
    background: var(--t-surface-2);
}

/* --- CATEGORIES / LOCATIONS (kart tabanli) --- */
.dark-mode .necox-category-card,
.dark-mode .necox-location-card {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-category-card__title,
.dark-mode .necox-location-card__title {
    color: var(--t-heading);
}

.dark-mode .necox-category-card__count,
.dark-mode .necox-location-card__count {
    color: var(--t-text-muted);
}

/* --- FILTER SIDEBAR --- */
.dark-mode .necox-filter,
.dark-mode .necox-filter__group,
.dark-mode .necox-filter__panel {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-filter__title,
.dark-mode .necox-filter__group-title {
    color: var(--t-heading);
}

/* --- BLOG --- */
.dark-mode .necox-blog__post,
.dark-mode .necox-blog__card,
.dark-mode .necox-blog__sidebar,
.dark-mode .necox-blog__featured,
.dark-mode .necox-blog__meta,
.dark-mode .necox-blog__toc,
.dark-mode .necox-blog__author-box,
.dark-mode .necox-blog__related,
.dark-mode .necox-blog__category-list {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-blog__title,
.dark-mode .necox-blog__post-title,
.dark-mode .necox-blog__card-title,
.dark-mode .necox-blog__toc-title,
.dark-mode .necox-blog__section-title {
    color: var(--t-heading);
}

.dark-mode .necox-blog__excerpt,
.dark-mode .necox-blog__date,
.dark-mode .necox-blog__read-time,
.dark-mode .necox-blog__author-bio {
    color: var(--t-text-muted);
}

.dark-mode .necox-blog__category-link {
    color: var(--t-text-soft);
}

.dark-mode .necox-blog__category-link:hover,
.dark-mode .necox-blog__category-link.is-active {
    background: var(--t-surface-2);
    color: var(--t-link);
}

.dark-mode .necox-blog__toc-link {
    color: var(--t-text-soft);
}

.dark-mode .necox-blog__toc-link:hover,
.dark-mode .necox-blog__toc-link.is-active {
    color: var(--t-link);
}

.dark-mode .necox-blog__share-btn {
    background: var(--t-surface-2);
    color: var(--t-text);
}

/* Yorum formu */
.dark-mode .comment-respond,
.dark-mode .comment-form,
.dark-mode .comment-list .comment-body {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- COMPARE (tablo + modal) --- */
.dark-mode .necox-compare,
.dark-mode .necox-compare__table,
.dark-mode .necox-compare__modal,
.dark-mode .necox-compare__modal-inner {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-compare__table th,
.dark-mode .necox-compare__table td {
    border-color: var(--t-border);
}

.dark-mode .necox-compare__feature-col {
    background: var(--t-surface-2);
    color: var(--t-text-soft);
}

.dark-mode .necox-compare__badge {
    background: rgba(30,41,59,0.92);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- CONTENT PAGES (terms/privacy/faq/sitemap/help) --- */
.dark-mode .necox-content-page,
.dark-mode .necox-content-card,
.dark-mode .necox-faq__item,
.dark-mode .necox-faq__tabs,
.dark-mode .necox-sitemap__section,
.dark-mode .necox-help__card,
.dark-mode .necox-help__search {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-faq__question,
.dark-mode .necox-help__card-title,
.dark-mode .necox-sitemap__section-title {
    color: var(--t-heading);
}

.dark-mode .necox-faq__answer,
.dark-mode .necox-help__card-desc {
    color: var(--t-text-soft);
}

.dark-mode .necox-faq__tab {
    color: var(--t-text-soft);
}

.dark-mode .necox-faq__tab.is-active {
    background: var(--t-surface-2);
    color: var(--t-link);
}

/* --- AUTH SAYFALARI (forgot password, verify email, login modal) --- */
.dark-mode .necox-auth-card,
.dark-mode .necox-login-modal__inner,
.dark-mode .necox-auth__form,
.dark-mode .necox-auth__panel {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-auth-card__title,
.dark-mode .necox-login-modal__title {
    color: var(--t-heading);
}

.dark-mode .necox-auth-card__sub,
.dark-mode .necox-login-modal__sub {
    color: var(--t-text-muted);
}

/* --- CONTACT --- */
.dark-mode .necox-contact,
.dark-mode .necox-contact__form,
.dark-mode .necox-contact__info,
.dark-mode .necox-contact__map {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- 404 SAYFASI --- */
.dark-mode .necox-404,
.dark-mode .necox-404__card {
    background: var(--t-surface);
    color: var(--t-text);
}

.dark-mode .necox-404__code,
.dark-mode .necox-404__title {
    color: var(--t-heading);
}

/* --- HAKKIMIZDA / PAGE BUILDER CARD'LARI --- */
.dark-mode .necox-pb-card,
.dark-mode .necox-about__team-card,
.dark-mode .necox-about__counter {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- PRICE TABLES / HOW-IT-WORKS / INFINITY-ADS / TEXT-SLIDER (kart elementleri) --- */
.dark-mode .necox-price__card,
.dark-mode .necox-hiw__card,
.dark-mode .necox-hiw__step,
.dark-mode .necox-text-slider__slide {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-price__title,
.dark-mode .necox-price__amount,
.dark-mode .necox-hiw__title {
    color: var(--t-heading);
}

.dark-mode .necox-price__feature,
.dark-mode .necox-hiw__desc {
    color: var(--t-text-soft);
}

/* --- PAGINATION / BREADCRUMB / TOAST / SKELETON / EMPTY-STATE --- */
/* Bu pc-* componentleri zaten token kullanir — sadece hover/aktif durumlar */

.dark-mode .necox-pagination__item {
    color: var(--t-text-soft);
    border-color: var(--t-border);
}

.dark-mode .necox-pagination__item:hover {
    background: var(--t-surface-2);
    color: var(--t-heading);
}

.dark-mode .necox-pagination__item.is-active {
    background: var(--t-link);
    color: var(--t-bg);
    border-color: var(--t-link);
}

.dark-mode .necox-breadcrumb {
    color: var(--t-text-muted);
}

.dark-mode .necox-breadcrumb a {
    color: var(--t-link);
}

.dark-mode .necox-toast {
    background: var(--t-surface-2);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-skeleton {
    background: linear-gradient(90deg, var(--t-surface) 0%, var(--t-surface-2) 50%, var(--t-surface) 100%);
}

.dark-mode .necox-empty-state {
    color: var(--t-text-muted);
}

.dark-mode .necox-empty-state__title {
    color: var(--t-heading);
}

/* --- SHARE BUTTONS --- */
.dark-mode .necox-share-btn {
    background: var(--t-surface-2);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-share-btn:hover {
    background: var(--t-surface);
    color: var(--t-heading);
}

/* --- MESSAGES / CONVERSATIONS --- */
.dark-mode .necox-msg,
.dark-mode .necox-msg-thread,
.dark-mode .necox-msg-modal,
.dark-mode .necox-msg-modal__inner,
.dark-mode .necox-conversation,
.dark-mode .necox-conversation__item {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-msg-bubble--in {
    background: var(--t-surface-2);
    color: var(--t-text);
}

.dark-mode .necox-msg-bubble--out {
    background: var(--t-link);
    color: var(--t-bg);
}

/* --- PACKAGES FRONTEND --- */
.dark-mode .necox-pkg,
.dark-mode .necox-pkg__card,
.dark-mode .necox-pkg__checkout,
.dark-mode .necox-pkg__success,
.dark-mode .necox-pkg__failed {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- PROMO / PROMOTE MODAL --- */
.dark-mode .necox-promo,
.dark-mode .necox-promote-modal,
.dark-mode .necox-promote-modal__inner {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- PROMOTION MAP (Leaflet popup) --- */
.dark-mode .necox-promo-map__popup,
.dark-mode .leaflet-popup-content-wrapper {
    background: var(--t-surface) !important;
    color: var(--t-text) !important;
}

.dark-mode .leaflet-popup-tip {
    background: var(--t-surface) !important;
}

/* --- DASHBOARD EK (stat chart, aktif panel) --- */
.dark-mode .necox-dash-chart,
.dark-mode .necox-dash-section,
.dark-mode .necox-dash-table {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-dash-table th {
    background: var(--t-surface-2);
    color: var(--t-text-soft);
}

/* --- POST-AD FORMU --- */
.dark-mode .necox-post-ad,
.dark-mode .necox-post-ad__preview,
.dark-mode .necox-post-ad__section,
.dark-mode .necox-post-ad__card {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

.dark-mode .necox-post-ad__progress {
    background: var(--t-surface-2);
}

.dark-mode .necox-post-ad__progress-fill {
    background: var(--t-link);
}

/* --- BELL NOTIFICATIONS panel (ek override) --- */
.dark-mode .necox-bell__panel,
.dark-mode .necox-bell__list {
    background: var(--t-surface);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- LANG SWITCHER panel --- */
.dark-mode .necox-lang-switcher__item {
    color: var(--t-text-soft);
}

.dark-mode .necox-lang-switcher__item:hover,
.dark-mode .necox-lang-switcher__item.is-active {
    background: var(--t-surface-2);
    color: var(--t-heading);
}

/* --- PAGE BUILDER DEMO BAR (frontend) --- */
.dark-mode .necox-pb-demo-bar {
    background: var(--t-surface-2);
    color: var(--t-text);
    border-color: var(--t-border);
}

/* --- SHADOW YUMUSAT (dark mode'da beyaz shadow yanlis durur) --- */
.dark-mode .necox-card,
.dark-mode .necox-ad-card,
.dark-mode .necox-seller-card,
.dark-mode .necox-blog__card {
    box-shadow: var(--necox-shadow);
}

.dark-mode .necox-card:hover,
.dark-mode .necox-ad-card:hover,
.dark-mode .necox-seller-card:hover,
.dark-mode .necox-blog__card:hover {
    box-shadow: var(--necox-shadow-hover);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   REPORT MODAL — DARK MODE (v3.51.1)
   Admin tanimli ozel renkleri EZMEYECEK sekilde sadece
   varsayilan/fallback durumlarda devreye girer. report-modal.css
   `var(--necox-report-bg, var(--necox-white, #fff))` pattern'i kullanir;
   dark mode'da --necox-white zaten koyu, bu yuzden cogu sey kendiliginden
   duzelir. Ama overlay/thumb/feedback gibi hardcoded yerler icin ek
   override'lar gerekiyor.
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Inner panel — token zinciri cozmezse manuel fallback */
.dark-mode .necox-report-modal__inner {
    background: var(--necox-report-bg, var(--t-surface));
    color: var(--necox-report-text-color, var(--t-text));
    border-color: var(--necox-report-border-color, var(--t-border));
}

/* Overlay — varsayilan rgba(0,0,0,0.65) dark mode'da cok yetersiz */
.dark-mode .necox-report-modal__overlay {
    background: var(--necox-report-overlay, rgba(0, 0, 0, 0.8));
}

/* Baslik ve alt metin */
.dark-mode .necox-report-modal__title {
    color: var(--necox-report-title-color, var(--t-heading));
}
.dark-mode .necox-report-modal__sub {
    color: var(--necox-report-sub-color, var(--t-text-muted));
}

/* Kapatma butonu */
.dark-mode .necox-report-modal__close {
    color: var(--t-text-muted);
}
.dark-mode .necox-report-modal__close:hover {
    color: var(--t-heading);
}

/* Preview kutu (ilan ozeti) */
.dark-mode .necox-report-modal__preview {
    background: var(--t-surface-2);
    border-color: var(--t-border);
}
.dark-mode .necox-report-modal__preview-thumb {
    background: var(--t-muted);
    color: var(--t-text-muted);
}
.dark-mode .necox-report-modal__preview-title {
    color: var(--t-heading);
}
.dark-mode .necox-report-modal__preview-price,
.dark-mode .necox-report-modal__preview-location {
    color: var(--t-text-muted);
}

/* Etiketler */
.dark-mode .necox-report-modal__select-label > span,
.dark-mode .necox-report-modal__textarea-label > span {
    color: var(--necox-report-label-color, var(--t-text-soft));
}

/* Select ve textarea — dark-mode genel input override'i zaten var,
   burada spesifite icin pekistir. */
.dark-mode .necox-report-modal__select,
.dark-mode .necox-report-modal__textarea-label textarea {
    background: var(--necox-input-bg);
    color: var(--t-text);
    border-color: var(--necox-input-border);
}
.dark-mode .necox-report-modal__textarea-label textarea::placeholder {
    color: var(--t-text-muted);
    opacity: 0.7;
}

/* Karakter sayaci */
.dark-mode .necox-report-modal__char-count {
    color: var(--t-text-muted);
}
.dark-mode .necox-report-modal__char-count.is-warn {
    color: var(--t-warning);
}

/* Geri bildirim mesaji */
.dark-mode .necox-report-modal__feedback.is-success {
    background: rgba(52, 211, 153, 0.12);
    color: var(--t-success);
    border-color: rgba(52, 211, 153, 0.3);
}
.dark-mode .necox-report-modal__feedback.is-error {
    background: rgba(248, 113, 113, 0.12);
    color: var(--t-error);
    border-color: rgba(248, 113, 113, 0.3);
}
.dark-mode .necox-report-modal__feedback.is-info {
    background: rgba(96, 165, 250, 0.12);
    color: var(--t-info);
    border-color: rgba(96, 165, 250, 0.3);
}

/* Iptal butonu — admin gradient tanimli degilse dark mode'a uyarla */
.dark-mode .necox-report-modal__btn--cancel {
    background: var(--t-surface-2);
    color: var(--t-text);
    border-color: var(--t-border);
}
.dark-mode .necox-report-modal__btn--cancel:hover {
    background: var(--t-muted);
    color: var(--t-heading);
}

/* Glass modifier (opacity 0.X beyaz) — dark mode'da koyu cam uret */
.dark-mode .necox-report-modal--glass .necox-report-modal__inner {
    background: rgba(30, 41, 59, 0.78);
}

