/**
 * Trendmetrik — ortak UI primitives (TRE UI system)
 * theme-variables.css token'larına bağlı; yeni sayfalarda bu sınıfları tercih edin.
 */

/* --- Page stack --- */
.tm-stack {
  display: flex;
  flex-direction: column;
  gap: var(--tm-section-gap, 16px);
  width: 100%;
}

.tm-stack--tight {
  gap: 0.75rem;
}

/* --- Card / panel --- */
.tm-card {
  background: var(--tm-bg-card, var(--color-surface));
  border: 1px solid var(--tm-border-color, var(--color-border));
  border-radius: var(--radius-token-md, 14px);
  box-shadow: var(--tm-shadow-md, 0 4px 6px rgba(0, 0, 0, 0.06));
  padding: 1rem 1.25rem;
}

.tm-card--flat {
  box-shadow: none;
}

.tm-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.tm-card__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--tm-text-primary, var(--color-text));
}

.tm-card__sub {
  margin: 0.25rem 0 0;
  font-size: 0.8125rem;
  color: var(--tm-text-secondary, var(--color-text-muted));
}

html.dark-mode .tm-card {
  box-shadow: var(--shadow-card);
}

/* --- Table --- */
.tm-table-wrap {
  width: 100%;
  overflow-x: auto;
  border-radius: var(--radius-token-md, 14px);
  border: 1px solid var(--tm-border-color);
}

.tm-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.tm-table thead th {
  text-align: left;
  padding: 0.65rem 0.85rem;
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--tm-text-secondary);
  background: var(--tm-bg-tertiary);
  border-bottom: 1px solid var(--tm-border-color);
}

.tm-table tbody td {
  padding: 0.65rem 0.85rem;
  border-bottom: 1px solid var(--tm-border-subtle, var(--tm-border-light));
  color: var(--tm-text-primary);
}

.tm-table tbody tr:hover td {
  background: var(--tm-table-row-hover-bg, var(--tm-bg-hover));
}

/* --- Buttons --- */
.tm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 600;
  font-size: 0.875rem;
  border-radius: 10px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.tm-btn--primary {
  background: var(--color-primary);
  color: var(--tm-fg-on-brand, #fff);
  border-color: var(--color-primary);
  box-shadow: 0 2px 8px rgba(var(--color-primary-rgb), 0.25);
}

.tm-btn--primary:hover:not(:disabled) {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}

.tm-btn--ghost {
  background: transparent;
  color: var(--tm-text-primary);
  border-color: var(--tm-border-color);
}

.tm-btn--ghost:hover:not(:disabled) {
  background: var(--tm-bg-hover);
  border-color: var(--tm-border-color);
}

.tm-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

/* --- Badges --- */
.tm-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.2rem 0.55rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  border-radius: 999px;
  line-height: 1.2;
}

.tm-badge--success {
  background: var(--tm-success-bg);
  color: var(--tm-success);
  border: 1px solid var(--tm-success-border);
}

.tm-badge--warning {
  background: var(--tm-warning-bg);
  color: var(--tm-warning);
  border: 1px solid var(--tm-warning-border);
}

.tm-badge--danger {
  background: var(--tm-error-bg);
  color: var(--tm-error);
  border: 1px solid var(--tm-error-border);
}

html.dark-mode .tm-badge--success {
  background: rgba(var(--color-success-rgb), 0.12);
  color: var(--tm-success-light);
  border-color: rgba(var(--color-success-rgb), 0.35);
}

html.dark-mode .tm-badge--danger {
  background: rgba(var(--color-danger-rgb), 0.12);
  color: var(--tm-error-light);
  border-color: rgba(var(--color-danger-rgb), 0.35);
}

/* --- Modal / dialog surface (Bootstrap .modal-content ile birlikte kullanılabilir) --- */
.tm-modal-surface {
  border-radius: var(--radius-token-lg, 18px) !important;
  border: 1px solid var(--tm-border-color) !important;
  background: var(--tm-bg-card) !important;
  box-shadow: var(--tm-shadow-lg) !important;
}

/*
 * TM v2 — Bootstrap 5 modal katmanı (tek kaynak z-index: tm-z-layers.css)
 * Kullanım: içerik #tmv2App dışına taşınmalı (base.html tmMoveBootstrapModalsToBody).
 * İsim eşlemesi: .modal = tam ekran | .modal-dialog = kutu | .modal-content = yüzey
 */
.tmv2-modal-backdrop {
  /* Bootstrap .modal-backdrop ile aynı rol; özel instance gerekirse */
  z-index: var(--tm-z-modal-backdrop, 1050);
}

.tmv2-guide-modal.modal.show {
  z-index: var(--tm-z-modal, 1055) !important;
}

/* --- Toast stack (mevcut toast ile uyum) --- */
.tm-toast-host {
  position: fixed;
  z-index: var(--tm-z-toast, 10800);
  pointer-events: none;
}

/* --- Skeleton --- */
.tm-skeleton {
  height: 1rem;
  border-radius: 8px;
  background: linear-gradient(
    90deg,
    var(--tm-bg-tertiary) 0%,
    var(--tm-bg-hover) 50%,
    var(--tm-bg-tertiary) 100%
  );
  background-size: 200% 100%;
  animation: tm-skeleton-shimmer 1.2s ease-in-out infinite;
}

.tm-skeleton--h2 {
  height: 2rem;
  width: 40%;
}

.tm-skeleton--line {
  height: 0.75rem;
  width: 100%;
}

@keyframes tm-skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

/* --- Empty / error --- */
.tm-empty-state {
  text-align: center;
  padding: 2rem 1.25rem;
  color: var(--tm-text-secondary);
  border: 1px dashed var(--tm-border-color);
  border-radius: var(--radius-token-md);
  background: var(--tm-bg-secondary);
}

.tm-empty-state__title {
  margin: 0 0 0.35rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--tm-text-primary);
}

.tm-error-state {
  border: 1px solid var(--tm-error-border);
  background: var(--tm-error-bg);
  color: var(--tm-error);
  border-radius: var(--radius-token-md);
  padding: 1rem 1.25rem;
}

html.dark-mode .tm-error-state {
  background: rgba(var(--color-danger-rgb), 0.12);
  color: var(--tm-error-light);
  border-color: rgba(var(--color-danger-rgb), 0.35);
}

/* --- Progress --- */
.tm-progress {
  height: 6px;
  border-radius: 999px;
  background: var(--tm-bg-tertiary);
  overflow: hidden;
}

.tm-progress__bar {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), var(--color-secondary));
  transition: width 0.35s ease;
}

/* ============ V2 SURFACE SYSTEM ============ */
/* Solid surface classes — blocks background grid from showing through */

.tmv2-surface {
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6);
  border-radius: var(--tmv2-r-lg, 14px);
}

.tmv2-surface-card {
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6);
  border-radius: var(--tmv2-r-lg, 14px);
  box-shadow: var(--tmv2-sh-1, 0 1px 3px rgba(15,23,42,.05));
}

.tmv2-surface-soft {
  background: var(--tmv2-surface-2, #fafbfd) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6);
  border-radius: var(--tmv2-r-md, 10px);
}

/* Force solid surface on common page containers inside v2 shell */
#tmv2App .wide-container,
#tmv2App .profit-margin-page,
#tmv2App .order-profit-page,
#tmv2App .product-profit-page,
#tmv2App .category-profit-page,
#tmv2App .xml-page,
#tmv2App .xml-sources-page,
#tmv2App .alerts-page,
#tmv2App .product-management-page,
#tmv2App .monitoring-container,
#tmv2App .app-container,
#tmv2App .commission-page,
#tmv2App .advantage-page,
#tmv2App .plus-commission-page {
  background: transparent;
  border-radius: 0;
  border: none;
  padding: 0;
  box-shadow: none;
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}

/* Override page-specific max-width/padding variables that differ from v2 */
#tmv2App .app-container {
  --page-container-max-width: 100%;
  --page-container-padding-x: 0;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Container-fluid inside v2: no extra padding (prevents double-gutter) */
#tmv2App .container-fluid {
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Tables and filter bars: solid white background */
#tmv2App .table-responsive,
#tmv2App .table-container,
#tmv2App .filter-bar,
#tmv2App .filter-section,
#tmv2App .profit-filters {
  background: var(--tmv2-surface, #ffffff);
  border-radius: var(--tmv2-r-lg, 14px);
}

/* Empty state panels: solid surface */
#tmv2App .empty-state,
#tmv2App .empty-state-container,
#tmv2App .no-data-message {
  background: var(--tmv2-surface, #ffffff);
  border: 1px solid var(--tmv2-line-2, #eef1f6);
  border-radius: var(--tmv2-r-lg, 14px);
  padding: 40px 24px;
}

/* Generic Bootstrap .card inside v2: solid white */
#tmv2App .card {
  background: var(--tmv2-surface, #ffffff) !important;
}

/* Dark mode surfaces */
html.dark-mode #tmv2App .wide-container,
html.dark-mode #tmv2App .profit-margin-page,
html.dark-mode #tmv2App .order-profit-page,
html.dark-mode #tmv2App .product-profit-page,
html.dark-mode #tmv2App .category-profit-page,
html.dark-mode #tmv2App .xml-page,
html.dark-mode #tmv2App .xml-sources-page,
html.dark-mode #tmv2App .alerts-page,
html.dark-mode #tmv2App .product-management-page,
html.dark-mode #tmv2App .monitoring-container {
  background: var(--tmv2-surface, #10151f);
  border-color: var(--tmv2-line, #1e2533);
}

html.dark-mode #tmv2App .card {
  background: var(--tmv2-surface, #10151f) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
}

/* ============ V2 PAGE NORMALIZATION ============ */
/* Force all legacy page wrappers into v2 visual system */

/* Page wrappers: transparent pass-through — inner panels provide surface */
#tmv2App .product-settings-page,
#tmv2App .admin-xml-page,
#tmv2App .product-profit-page-wrapper,
#tmv2App .order-profit-page,
#tmv2App .profit-margin-page-wrapper,
#tmv2App .tmv2-analysis-root,
#tmv2App .pricing-page,
#tmv2App .flash-offers-page {
  background: transparent;
  border-radius: 0;
  border: none;
  padding: 0;
  box-shadow: none;
}

/* Neutralize glass/blur effects inside v2 shell */
#tmv2App [style*="backdrop-filter"],
#tmv2App .glass,
#tmv2App .glass-card {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

#tmv2App .card,
#tmv2App .stat-card,
#tmv2App .pricing-card,
#tmv2App .calculator-card,
#tmv2App .settings-card,
#tmv2App .metric-card {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6) !important;
  border-radius: var(--tmv2-r-lg, 14px) !important;
  box-shadow: var(--tmv2-sh-1, 0 1px 3px rgba(15,23,42,.05)) !important;
}

/* Birincil düğüm renkleri — durumlar tm-buttons-v2.css (#tmv2App, Bootstrap ile uyum) */
#tmv2App .text-primary {
  color: var(--tmv2-primary) !important;
}

#tmv2App .bg-primary {
  background-color: var(--tmv2-primary) !important;
}

/* Tables: consistent styling */
#tmv2App table.table,
#tmv2App .table {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  font-size: 13px;
}

#tmv2App .table thead th {
  background: var(--tmv2-surface-2, #fafbfd) !important;
  border-bottom: 1px solid var(--tmv2-line, #e7ebf1) !important;
  font-weight: 600;
  font-size: 12px;
  color: var(--tmv2-ink-2, #475569);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 10px 12px;
}

#tmv2App .table tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--tmv2-line-2, #eef1f6);
  color: var(--tmv2-ink, #0f172a);
  vertical-align: middle;
}

#tmv2App .table tbody tr:hover {
  background: var(--tmv2-surface-2, #fafbfd) !important;
}

/* Page headers: consistent title styling */
#tmv2App .page-header,
#tmv2App .page-title-card,
#tmv2App .product-settings-page .card:first-child {
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line, #e7ebf1) !important;
  border-radius: var(--tmv2-r-xl, 18px) !important;
  box-shadow: var(--tmv2-sh-1) !important;
}

/* Pagination: v2 styled */
#tmv2App .pagination .page-link {
  color: var(--tmv2-primary) !important;
  border-color: var(--tmv2-line) !important;
  border-radius: var(--tmv2-r-md) !important;
}

#tmv2App .pagination .page-item.active .page-link {
  background: var(--tmv2-primary) !important;
  border-color: var(--tmv2-primary) !important;
  color: var(--tm-fg-on-brand) !important;
}

/* Badge: v2 consistent */
#tmv2App .badge {
  border-radius: 999px;
  font-weight: 600;
  font-size: 11px;
  padding: 3px 8px;
}

/* Input/Select: v2 consistent */
#tmv2App .form-control,
#tmv2App .form-select {
  border: 1px solid var(--tmv2-line, #e7ebf1) !important;
  border-radius: var(--tmv2-r-md, 10px) !important;
  font-size: 13px;
  padding: 8px 12px;
  background: var(--tmv2-surface, #ffffff);
  color: var(--tmv2-ink, #0f172a);
}

#tmv2App .form-control:focus,
#tmv2App .form-select:focus {
  border-color: var(--tmv2-primary) !important;
  box-shadow: var(--tmv2-form-focus-shadow) !important;
  outline: none;
}

/* Dark mode: all legacy pages */
html.dark-mode #tmv2App .product-settings-page,
html.dark-mode #tmv2App .admin-xml-page,
html.dark-mode #tmv2App .product-profit-page-wrapper,
html.dark-mode #tmv2App .order-profit-page,
html.dark-mode #tmv2App .profit-margin-page-wrapper,
html.dark-mode #tmv2App .tmv2-analysis-root,
html.dark-mode #tmv2App .pricing-page,
html.dark-mode #tmv2App .flash-offers-page {
  background: var(--tmv2-surface, #10151f);
  border-color: var(--tmv2-line, #1e2533);
}

html.dark-mode #tmv2App .card,
html.dark-mode #tmv2App .stat-card,
html.dark-mode #tmv2App .pricing-card,
html.dark-mode #tmv2App .metric-card {
  background: var(--tmv2-surface, #10151f) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
}

html.dark-mode #tmv2App .table thead th {
  background: var(--tmv2-surface-2, #0e131c) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
  color: var(--tmv2-ink-2, #9aa7bb);
}

html.dark-mode #tmv2App .table tbody td {
  border-color: var(--tmv2-line-2, #161c27);
  color: var(--tmv2-ink, #e6ecf5);
}

html.dark-mode #tmv2App .table tbody tr:hover {
  background: var(--tmv2-surface-2, #0e131c) !important;
}

html.dark-mode #tmv2App .form-control,
html.dark-mode #tmv2App .form-select {
  background: var(--tmv2-surface-2, #0e131c) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
  color: var(--tmv2-ink, #e6ecf5) !important;
}

/* ============ COMMISSION / ADVANTAGE / PLUS PAGES — V2 NORMALIZATION ============ */
/* These pages use pages-common.css + commission.css with orange palette.
   Override to match v2 system when inside #tmv2App. */

/* App container: transparent pass-through (parent already provides bg) */
#tmv2App .app-container {
  background: transparent !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Override page-specific variables with v2 tokens */
#tmv2App .app-container,
#tmv2App [class*="commission"],
#tmv2App [class*="advantage"],
#tmv2App [class*="plus-commission"] {
  --page-container-max-width: 100%;
  --page-container-padding-x: 0;
  --page-section-gap: 12px;
  --card-padding: 16px;
}

/* Header section: white surface, v2 radius */
#tmv2App .header-section {
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6) !important;
  border-radius: var(--tmv2-r-lg, 14px) !important;
  padding: 16px 20px !important;
  box-shadow: var(--tmv2-sh-1) !important;
  margin-bottom: 12px !important;
}

/* Header content: reduce vertical spacing */
#tmv2App .header-content {
  gap: 12px !important;
}

#tmv2App .header-top {
  gap: 12px !important;
}

/* Tool cards: v2 soft surface */
#tmv2App .header-tool-card {
  background: var(--tmv2-surface-2, #fafbfd) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6) !important;
  border-radius: var(--tmv2-r-md, 10px) !important;
  padding: 14px !important;
}

/* Table wrapper: v2 surface */
#tmv2App .table-wrapper {
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6) !important;
  border-radius: var(--tmv2-r-lg, 14px) !important;
  overflow: hidden;
  box-shadow: var(--tmv2-sh-1) !important;
}

/* Table header: compact */
#tmv2App .table-header {
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--tmv2-line-2, #eef1f6);
}

/* Commission card: use v2 surface instead of orange gradient */
#tmv2App .commission-card {
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6) !important;
  border-radius: var(--tmv2-r-md, 10px) !important;
}

/* Commission percentage badge: subtle, v2-aligned */
#tmv2App .commission-percentage {
  background: var(--tmv2-primary-soft) !important;
  color: var(--tmv2-primary-ink) !important;
  border-color: rgba(var(--color-primary-rgb), 0.2) !important;
}

/* Orange action icons: accent yumuşatma */
#tmv2App .header-tool-card .tool-icon {
  background: var(--tmv2-primary-soft) !important;
  color: var(--tmv2-primary) !important;
}

/* Filter/search section: compact */
#tmv2App .search-section,
#tmv2App .filter-section {
  background: var(--tmv2-surface, #ffffff) !important;
  border: 1px solid var(--tmv2-line-2, #eef1f6) !important;
  border-radius: var(--tmv2-r-lg, 14px) !important;
  padding: 12px 16px !important;
  margin-bottom: 12px !important;
}

/* Reduce excessive vertical margins on these pages */
#tmv2App .app-container > * + * {
  margin-top: 12px !important;
}

#tmv2App .app-container .header-section + .table-wrapper,
#tmv2App .app-container .header-section + .search-section,
#tmv2App .app-container .filter-section + .table-wrapper {
  margin-top: 12px !important;
}

/* Empty state inside commission/advantage pages */
#tmv2App .app-container .empty-state,
#tmv2App .table-wrapper .empty-state {
  background: var(--tmv2-surface, #ffffff) !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 32px 20px !important;
  min-height: auto !important;
}

/* Pagination: compact */
#tmv2App .pagination-section {
  padding: 10px 16px !important;
  border-top: 1px solid var(--tmv2-line-2, #eef1f6);
}

/* Dark mode overrides for commission pages */
html.dark-mode #tmv2App .header-section {
  background: var(--tmv2-surface, #10151f) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
}

html.dark-mode #tmv2App .header-tool-card {
  background: var(--tmv2-surface-2, #0e131c) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
}

html.dark-mode #tmv2App .table-wrapper {
  background: var(--tmv2-surface, #10151f) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
}

html.dark-mode #tmv2App .commission-card {
  background: var(--tmv2-surface-2, #0e131c) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
}

html.dark-mode #tmv2App .search-section,
html.dark-mode #tmv2App .filter-section {
  background: var(--tmv2-surface, #10151f) !important;
  border-color: var(--tmv2-line, #1e2533) !important;
}

/* ----- TM v2 — global surface contract (panel / card / metric / table) -----
   Layout (.tmv2-page-inner--wide vb.) yalnızca genişlik; bu blok görünümü tekilleştirir. ----- */
#tmv2App .tmv2-panel {
  box-sizing: border-box;
  background: var(--tmv2-surface);
  border: 1px solid var(--tmv2-border);
  border-radius: var(--tmv2-r-lg);
  box-shadow: var(--tmv2-sh-1);
  padding: var(--tmv2-sp-5);
  margin-bottom: 0;
}

#tmv2App .tmv2-panel.tmv2-panel--flush {
  padding: 0;
}

#tmv2App .tmv2-panel--warning {
  background: color-mix(in srgb, var(--tmv2-warning-soft) 28%, var(--tmv2-surface));
  border-color: color-mix(in srgb, var(--tmv2-warning) 32%, var(--tmv2-border));
}

html.dark-mode #tmv2App .tmv2-panel--warning {
  background: color-mix(in srgb, var(--tmv2-warning-soft) 18%, var(--tmv2-surface));
  border-color: color-mix(in srgb, var(--tmv2-warning-border) 35%, var(--tmv2-line));
}

#tmv2App .tmv2-card {
  box-sizing: border-box;
  background: var(--tmv2-surface);
  border: 1px solid var(--tmv2-border);
  border-radius: var(--tmv2-r-lg);
  box-shadow: var(--tmv2-sh-1);
  padding: var(--tmv2-sp-4);
  min-height: var(--tmv2-card-min-h);
}

#tmv2App .tmv2-metric-card {
  box-sizing: border-box;
  background: var(--tmv2-surface);
  border: 1px solid var(--tmv2-border);
  border-radius: var(--tmv2-r-lg);
  box-shadow: var(--tmv2-sh-1);
  padding: var(--tmv2-sp-4);
  min-height: var(--tmv2-metric-card-min-h);
}

#tmv2App .tmv2-kpi.tall {
  min-height: var(--tmv2-metric-card-tall-min-h);
}

#tmv2App .tmv2-metric-card--primary {
  background: radial-gradient(120% 180% at 100% 0%, rgba(255, 255, 255, 0.12), transparent 60%),
    var(--tmv2-kpi-accent-gradient);
  color: var(--tm-fg-on-brand);
  border-color: color-mix(in srgb, var(--tmv2-primary) 22%, transparent);
  box-shadow: var(--tmv2-sh-2);
}

#tmv2App .tmv2-metric-card--primary .k-label,
#tmv2App .tmv2-metric-card--primary .k-value {
  color: var(--tm-fg-on-brand);
}

#tmv2App .tmv2-metric-card--primary .k-en {
  color: rgba(255, 255, 255, 0.75);
}

/* İç içe: yalnızca dış panel çerçevesi güçlü; iç kartlar yumuşak */
#tmv2App .tmv2-panel .tmv2-card,
#tmv2App .tmv2-panel .tmv2-metric-card {
  border-color: color-mix(in srgb, var(--tmv2-border) 58%, var(--tmv2-surface));
  box-shadow: none;
}

#tmv2App .tmv2-panel .tmv2-metric-card--primary {
  border-color: color-mix(in srgb, var(--tmv2-primary) 28%, transparent);
  box-shadow: var(--tmv2-sh-1);
}

/* Hızlı erişim: küçük karo — global card min-height gevşet */
#tmv2App .tmv2-panel .quick-access-grid .tmv2-card {
  min-height: 0;
}

#tmv2App .tmv2-table-shell {
  border-color: var(--tmv2-border);
  background: var(--tmv2-surface);
  border-radius: var(--tmv2-r-lg);
  box-shadow: var(--tmv2-sh-1);
}

@media (max-width: 768px) {
  #tmv2App .tmv2-panel:not(.tmv2-panel--flush) {
    padding: var(--tmv2-sp-4);
  }
}

/* ----- Global page shell stack (any v2 page) ----- */
#tmv2App .tmv2-page-shell > .tmv2-section {
  display: flex;
  flex-direction: column;
  gap: var(--tmv2-section-gap);
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

#tmv2App .tmv2-page-shell .tmv2-panel {
  margin-bottom: 0;
}

/* In-page header band (card-style) */
#tmv2App .tmv2-page-header--card {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: var(--tmv2-sp-4) var(--tmv2-sp-3);
  background: var(--tmv2-surface);
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line));
  border-radius: var(--tmv2-r-lg);
  box-shadow: var(--tmv2-sh-1);
  box-sizing: border-box;
}

html.dark-mode #tmv2App .tmv2-page-header--card {
  border-color: var(--tmv2-line);
}

#tmv2App .tmv2-page-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--tmv2-ink);
  margin: 0;
  letter-spacing: -0.02em;
}

#tmv2App .tmv2-page-subtitle {
  margin: 0.15rem 0 0;
  font-size: 0.8125rem;
  color: var(--tmv2-ink-2);
}

#tmv2App .tmv2-section-lead h2 {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--tmv2-ink);
  margin: 0 0 0.25rem;
}

#tmv2App .tmv2-section-lead p {
  font-size: 0.8125rem;
  color: var(--tmv2-ink-2);
  margin: 0 0 var(--tmv2-sp-4);
}

/* Responsive grids */
#tmv2App .tmv2-section-grid--auto-4 {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: var(--tmv2-sp-3);
}

@media (min-width: 640px) {
  #tmv2App .tmv2-section-grid--auto-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  #tmv2App .tmv2-section-grid--auto-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* Step cards (wizard / onboarding — any page) */
#tmv2App .tmv2-step-card {
  position: relative;
  min-height: 5.75rem;
  box-sizing: border-box;
  padding: var(--tmv2-sp-4);
  border-radius: var(--tmv2-r-lg);
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line));
  background: var(--tmv2-surface-2);
  color: var(--tmv2-ink);
  box-shadow: var(--tmv2-sh-1);
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.15s ease;
}

#tmv2App .tmv2-step-card:hover {
  box-shadow: var(--tmv2-sh-2);
  border-color: var(--tmv2-line);
}

#tmv2App .tmv2-step-card--1 {
  background: color-mix(in srgb, var(--tmv2-primary) 10%, var(--tmv2-surface));
  border-color: color-mix(in srgb, var(--tmv2-primary) 28%, var(--tmv2-line));
}

#tmv2App .tmv2-step-card--2 {
  background: color-mix(in srgb, var(--tmv2-warning) 12%, var(--tmv2-surface));
  border-color: color-mix(in srgb, var(--tmv2-warning) 32%, var(--tmv2-line));
}

#tmv2App .tmv2-step-card--3 {
  background: color-mix(in srgb, var(--tmv2-info) 10%, var(--tmv2-surface));
  border-color: color-mix(in srgb, var(--tmv2-info) 28%, var(--tmv2-line));
}

#tmv2App .tmv2-step-card--4 {
  background: color-mix(in srgb, var(--tmv2-success) 10%, var(--tmv2-surface));
  border-color: color-mix(in srgb, var(--tmv2-success) 30%, var(--tmv2-line));
}

#tmv2App .tmv2-step-card__head {
  display: flex;
  align-items: center;
  gap: var(--tmv2-sp-3);
  margin-bottom: var(--tmv2-sp-2);
}

#tmv2App .tmv2-step-card__num {
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  border-radius: var(--tmv2-r-pill, 999px);
  font-size: 0.8125rem;
  font-weight: 700;
  background: var(--tmv2-surface);
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line));
  color: var(--tmv2-ink);
}

#tmv2App .tmv2-step-card--1 .tmv2-step-card__num {
  background: var(--tmv2-primary-soft);
  border-color: color-mix(in srgb, var(--tmv2-primary) 35%, var(--tmv2-line));
  color: var(--tmv2-primary);
}

#tmv2App .tmv2-step-card--2 .tmv2-step-card__num {
  background: var(--tmv2-warning-soft);
  border-color: color-mix(in srgb, var(--tmv2-warning) 40%, var(--tmv2-line));
  color: var(--tmv2-warning-border, var(--tmv2-warning));
}

#tmv2App .tmv2-step-card--3 .tmv2-step-card__num {
  background: var(--tmv2-info-soft);
  border-color: color-mix(in srgb, var(--tmv2-info) 35%, var(--tmv2-line));
  color: var(--tmv2-info-ink, var(--tmv2-info));
}

#tmv2App .tmv2-step-card--4 .tmv2-step-card__num {
  background: var(--tmv2-success-soft);
  border-color: color-mix(in srgb, var(--tmv2-success) 35%, var(--tmv2-line));
  color: var(--tmv2-success);
}

#tmv2App .tmv2-step-card__title {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--tmv2-ink);
  margin: 0;
  line-height: 1.25;
}

#tmv2App .tmv2-step-card__desc {
  font-size: 0.75rem;
  line-height: 1.45;
  color: var(--tmv2-ink-2);
  margin: 0;
}

@keyframes tmv2-step-card-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#tmv2App .tmv2-step-card {
  animation: tmv2-step-card-in 0.45s ease-out backwards;
}

#tmv2App .tmv2-section-grid--auto-4 .tmv2-step-card:nth-child(1) {
  animation-delay: 0.04s;
}

#tmv2App .tmv2-section-grid--auto-4 .tmv2-step-card:nth-child(2) {
  animation-delay: 0.08s;
}

#tmv2App .tmv2-section-grid--auto-4 .tmv2-step-card:nth-child(3) {
  animation-delay: 0.12s;
}

#tmv2App .tmv2-section-grid--auto-4 .tmv2-step-card:nth-child(4) {
  animation-delay: 0.16s;
}

/* Block heading (icon + title) */
#tmv2App .tmv2-block-head {
  display: flex;
  align-items: center;
  gap: var(--tmv2-sp-3);
  margin: 0 0 var(--tmv2-sp-3);
}

#tmv2App .tmv2-block-head__icon {
  width: 2rem;
  height: 2rem;
  border-radius: var(--tmv2-r-md);
  display: grid;
  place-items: center;
  background: var(--tmv2-primary-soft);
  color: var(--tmv2-primary);
  flex-shrink: 0;
}

#tmv2App .tmv2-block-head h3 {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--tmv2-ink);
}

/* Compact action links (grid of shortcuts) */
#tmv2App a.tmv2-action-card {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--tmv2-sp-3);
  min-height: 4.25rem;
  padding: var(--tmv2-sp-3) var(--tmv2-sp-4);
  border-radius: var(--tmv2-r-lg);
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line));
  background: var(--tmv2-surface-2);
  box-shadow: var(--tmv2-sh-1);
  text-decoration: none !important;
  color: var(--tmv2-ink) !important;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.15s ease;
}

#tmv2App a.tmv2-action-card:hover {
  box-shadow: var(--tmv2-sh-2);
  border-color: var(--tmv2-line);
  transform: translateY(-1px);
}

#tmv2App .tmv2-action-card__icon {
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  border-radius: var(--tmv2-r-md);
  display: grid;
  place-items: center;
}

#tmv2App .tmv2-action-card__icon svg {
  width: 1.25rem;
  height: 1.25rem;
}

#tmv2App .tmv2-action-card__label {
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--tmv2-ink);
}

#tmv2App a.tmv2-action-card--primary .tmv2-action-card__icon {
  background: var(--tmv2-primary-soft);
  color: var(--tmv2-primary);
}

#tmv2App a.tmv2-action-card--primary {
  border-color: color-mix(in srgb, var(--tmv2-primary) 30%, var(--tmv2-line));
  background: color-mix(in srgb, var(--tmv2-primary) 6%, var(--tmv2-surface));
}

#tmv2App a.tmv2-action-card--danger .tmv2-action-card__icon {
  background: var(--tmv2-danger-soft);
  color: var(--tmv2-danger);
}

#tmv2App a.tmv2-action-card--danger {
  border-color: color-mix(in srgb, var(--tmv2-danger) 28%, var(--tmv2-line));
  background: color-mix(in srgb, var(--tmv2-danger) 6%, var(--tmv2-surface));
}

#tmv2App a.tmv2-action-card--info .tmv2-action-card__icon {
  background: var(--tmv2-info-soft);
  color: var(--tmv2-info-ink, var(--tmv2-info));
}

#tmv2App a.tmv2-action-card--info {
  border-color: color-mix(in srgb, var(--tmv2-info) 26%, var(--tmv2-line));
  background: color-mix(in srgb, var(--tmv2-info) 6%, var(--tmv2-surface));
}

#tmv2App a.tmv2-action-card--success .tmv2-action-card__icon {
  background: var(--tmv2-success-soft);
  color: var(--tmv2-success);
}

#tmv2App a.tmv2-action-card--success {
  border-color: color-mix(in srgb, var(--tmv2-success) 28%, var(--tmv2-line));
  background: color-mix(in srgb, var(--tmv2-success) 6%, var(--tmv2-surface));
}

/* List + table chrome */
#tmv2App .tmv2-list-panel {
  margin-top: var(--tmv2-sp-4);
}

#tmv2App .tmv2-list-panel > .tmv2-table-shell {
  border-radius: var(--tmv2-r-lg);
  overflow: visible;
}

#tmv2App .tmv2-table-toolbar {
  padding: var(--tmv2-sp-3) var(--tmv2-sp-4);
  background: var(--tmv2-surface-2);
  border-bottom: 1px solid var(--tmv2-line-2, var(--tmv2-line));
}

#tmv2App .tmv2-table-toolbar__icon {
  width: 2rem;
  height: 2rem;
  border-radius: var(--tmv2-r-md);
  display: grid;
  place-items: center;
  background: var(--tmv2-surface);
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line));
  color: var(--tmv2-ink-2);
}

#tmv2App .tmv2-table-toolbar h3 {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--tmv2-ink);
}

#tmv2App .tmv2-table-toolbar p {
  margin: 0.1rem 0 0;
  font-size: 0.75rem;
  color: var(--tmv2-ink-2);
}

#tmv2App .tmv2-stat-chip {
  padding: var(--tmv2-sp-2) var(--tmv2-sp-3);
  border-radius: var(--tmv2-r-md);
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line));
  background: var(--tmv2-surface);
}

#tmv2App .tmv2-stat-chip__label {
  font-size: 0.6875rem;
  color: var(--tmv2-ink-2);
}

#tmv2App .tmv2-stat-chip__val {
  font-size: 1rem;
  font-weight: 700;
  color: var(--tmv2-ink);
  font-variant-numeric: tabular-nums;
}

#tmv2App .tmv2-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
}

#tmv2App table.xml-sources-table thead tr {
  background: var(--tmv2-surface-2);
  border-bottom: 1px solid var(--tmv2-line-2, var(--tmv2-line));
}

#tmv2App table.xml-sources-table th {
  color: var(--tmv2-ink-2);
  font-weight: 600;
  border-color: transparent;
}

#tmv2App table.xml-sources-table tbody tr {
  border-color: var(--tmv2-line-2, var(--tmv2-line));
}

#tmv2App table.xml-sources-table tbody tr:hover {
  background: color-mix(in srgb, var(--tmv2-ink) 4%, var(--tmv2-surface));
}

#tmv2App .tmv2-entity-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--tmv2-r-md);
  display: grid;
  place-items: center;
  background: var(--tmv2-primary-soft);
  border: 1px solid color-mix(in srgb, var(--tmv2-primary) 22%, var(--tmv2-line));
  color: var(--tmv2-primary);
}

/* ----- Wide / fluid page inner (#tmv2App) ----- */
#tmv2App .tmv2-page-inner.tmv2-page-inner--wide {
  max-width: min(100%, var(--tmv2-page-inner-wide-max, 1920px));
}

/* Operations / buybox: aynı genişlik üst sınırı — özel sayfa max-width yok */
#tmv2App .tmv2-page-inner.tmv2-page-inner--ops {
  max-width: min(100%, var(--tmv2-page-inner-wide-max, 1920px));
}

#tmv2App .tmv2-page-inner.tmv2-page-inner--fluid {
  max-width: none;
}

/* Bağımsız geniş sarmalayıcı (ör. ürün ayarları) */
#tmv2App .tmv2-page-inner--wide:not(.tmv2-page-inner) {
  max-width: min(100%, var(--tmv2-page-inner-wide-max, 1920px));
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  box-sizing: border-box;
}

/* Ops dashboard: primary column + sidebar rail */
#tmv2App .tmv2-ops-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: var(--tmv2-sp-4);
  align-items: start;
  width: 100%;
}

@media (max-width: 991.98px) {
  #tmv2App .tmv2-ops-grid {
    grid-template-columns: 1fr;
  }
}

/* Bootstrap .card + .tmv2-metric-card gövdesi */
#tmv2App .tmv2-metric-card .card-body {
  padding: var(--tmv2-sp-4);
}

/* Generic action panel */
#tmv2App .tmv2-action-panel {
  background: var(--tmv2-surface);
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line));
  border-radius: var(--tmv2-r-lg);
  box-shadow: var(--tmv2-sh-1);
  padding: var(--tmv2-sp-4);
  box-sizing: border-box;
}

#tmv2App .tmv2-empty-state--compact {
  padding: var(--tmv2-sp-5) var(--tmv2-sp-4);
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}

/* Commission / Plus / Advantage — shared .app-container layout */
#tmv2App .app-container {
  --page-max-width: min(100%, var(--tmv2-page-inner-wide-max, 1920px));
}

#tmv2App .app-container .header-text h1,
#tmv2App .app-container .header-text h1.m-0 {
  font-size: 1.35rem !important;
  line-height: 1.25 !important;
  font-weight: 700 !important;
  margin-bottom: 0.25rem !important;
  color: var(--tmv2-ink) !important;
}

#tmv2App .app-container .header-text p,
#tmv2App .app-container .header-text p.mt-1 {
  font-size: 0.875rem !important;
  line-height: 1.45 !important;
  color: var(--tmv2-ink-2) !important;
}

#tmv2App .app-container .header-section {
  background: var(--tmv2-surface) !important;
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line)) !important;
  border-radius: var(--tmv2-r-lg) !important;
  box-shadow: var(--tmv2-sh-1) !important;
  padding: 0 var(--tmv2-sp-3) !important;
  margin-top: var(--tmv2-sp-3) !important;
}

#tmv2App .app-container .header-content {
  padding: var(--tmv2-sp-3) 0 !important;
  gap: var(--tmv2-sp-3) !important;
}

#tmv2App .app-container .header-tool-card {
  background: var(--tmv2-surface-2) !important;
  border: 1px solid var(--tmv2-line-2, var(--tmv2-line)) !important;
  border-radius: var(--tmv2-r-md) !important;
  box-shadow: var(--tmv2-sh-1) !important;
}

/* Primary blue instead of orange for Bootstrap warning CTAs in these flows */
#tmv2App .app-container .btn-warning {
  background: var(--tmv2-primary) !important;
  border-color: var(--tmv2-primary) !important;
  color: var(--tm-fg-on-brand) !important;
}

#tmv2App .app-container .btn-warning:hover,
#tmv2App .app-container .btn-warning:focus {
  background: var(--tmv2-primary-hover, var(--color-primary-hover)) !important;
  border-color: var(--tmv2-primary-hover, var(--color-primary-hover)) !important;
  color: var(--tm-fg-on-brand) !important;
}

#tmv2App .app-container .btn-bulk-primary {
  background: var(--tmv2-primary) !important;
  box-shadow: var(--tmv2-sh-2) !important;
  color: var(--tm-fg-on-brand) !important;
}

#tmv2App .app-container .btn-bulk-primary:hover {
  filter: brightness(0.97);
}

#tmv2App .app-container .bulk-select-type-pill:hover {
  border-color: color-mix(in srgb, var(--tmv2-primary) 35%, var(--tmv2-line)) !important;
  background: var(--tmv2-primary-soft) !important;
}

#tmv2App .app-container .bulk-select-type-pill input {
  accent-color: var(--tmv2-primary) !important;
}

#tmv2App .app-container .bulk-select-panel__body .form-input:focus,
#tmv2App .app-container .bulk-select-panel__body select:focus {
  border-color: color-mix(in srgb, var(--tmv2-primary) 45%, var(--tmv2-line)) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--tmv2-primary) 18%, transparent) !important;
  outline: none !important;
}

#tmv2App .tmv2-upload-dropzone {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 6.5rem;
  padding: var(--tmv2-sp-4);
  border-radius: var(--tmv2-r-lg);
  border: 2px dashed var(--tmv2-line-2, var(--tmv2-line));
  background: var(--tmv2-surface-2);
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}

#tmv2App .tmv2-upload-dropzone:hover {
  border-color: color-mix(in srgb, var(--tmv2-primary) 40%, var(--tmv2-line));
  background: var(--tmv2-surface);
}

/* Ürün ayarları — shell arka planı token ile */
#tmv2App .product-settings-page .min-vh-100.bg-light {
  background: transparent !important;
}

#tmv2App .profit-margin-page .wide-container {
  max-width: min(100%, var(--tmv2-page-inner-wide-max, 2200px));
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--tmv2-sp-3);
  padding-right: var(--tmv2-sp-3);
  box-sizing: border-box;
}

/* Üst küçük etiket (buybox / paneller) */
#tmv2App .tmv2-kicker {
  margin: 0 0 0.35rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tmv2-ink-2);
}

/* Genel Bakış — maliyet uyarısı: token yüzey (dashboard-tabbed .alert-card !important üstüne) */
#tmv2App #overviewTab .cost-warning-banner--critical.tmv2-panel.tmv2-panel--warning {
  background: color-mix(in srgb, var(--tmv2-danger-soft) 55%, var(--tmv2-surface)) !important;
  border: 1px solid color-mix(in srgb, var(--tmv2-danger) 32%, var(--tmv2-border)) !important;
  border-left: 4px solid var(--tmv2-danger) !important;
  border-radius: var(--tmv2-r-lg) !important;
  box-shadow: var(--tmv2-sh-1) !important;
}

#tmv2App #overviewTab .cost-warning-banner.tmv2-panel--flush .cost-warning-content {
  padding: var(--tmv2-sp-4) var(--tmv2-sp-5);
  box-sizing: border-box;
}

html.dark-mode #tmv2App #overviewTab .cost-warning-banner--critical.tmv2-panel.tmv2-panel--warning {
  background: color-mix(in srgb, var(--tmv2-danger-soft) 22%, var(--tmv2-surface)) !important;
  border-color: color-mix(in srgb, var(--tmv2-danger) 40%, var(--tmv2-line)) !important;
}
