/*
 * Mintweb — Paylaşılan Component Sınıfları
 * --------------------------------------------------------------
 * Tailwind compile akışı henüz aktif olmadığı için (Phase 18+),
 * Phase 3 design system "ham CSS class" yüzeyiyle hizmet verir.
 * Bu dosya hem Django design-test sayfasında hem de React dev
 * sayfasında AYNEN import edilir — visual parity'nin kaynağı budur.
 *
 * Tüm değerler design-tokens.css'teki CSS variable'lara bağlıdır.
 */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* --- Düzen --- */
.ds-container {
  max-width: 960px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-4);
}

.ds-stack > * + * {
  margin-top: var(--space-6);
}

.ds-row {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
}

.ds-grid {
  display: grid;
  gap: var(--space-4);
}

.ds-grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-grid-cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ds-grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* --- Tipografi --- */
.ds-h1 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  margin: 0 0 var(--space-2);
  letter-spacing: -0.02em;
}

.ds-h2 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  margin: 0 0 var(--space-3);
  letter-spacing: -0.01em;
}

.ds-h3 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  margin: 0 0 var(--space-2);
}

.ds-text {
  font-size: var(--font-size-base);
  color: var(--color-fg);
}

.ds-text-muted {
  color: var(--color-fg-muted);
  font-size: var(--font-size-sm);
}

.ds-mono {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
}

/* --- Buton --- */
.ds-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: 2.25rem;
  padding: 0 var(--space-4);
  font-family: inherit;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  border: 1px solid transparent;
  border-radius: var(--radius);
  cursor: pointer;
  transition:
    background-color var(--transition),
    border-color var(--transition),
    color var(--transition),
    box-shadow var(--transition);
  user-select: none;
  white-space: nowrap;
}

.ds-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.ds-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.ds-btn-primary {
  background: var(--color-primary);
  color: var(--color-primary-fg);
  border-color: var(--color-primary);
}

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

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

.ds-btn-secondary {
  background: var(--color-bg);
  color: var(--color-fg);
  border-color: var(--color-border);
}

.ds-btn-secondary:hover:not(:disabled) {
  background: var(--color-bg-subtle);
  border-color: var(--color-border-strong);
}

.ds-btn-ghost {
  background: transparent;
  color: var(--color-fg);
  border-color: transparent;
}

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

.ds-btn-danger {
  background: var(--color-danger);
  color: #ffffff;
  border-color: var(--color-danger);
}

.ds-btn-danger:hover:not(:disabled) {
  filter: brightness(0.95);
}

/* --- Form alanları --- */
.ds-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-fg);
  margin-bottom: var(--space-2);
}

.ds-input,
.ds-textarea,
.ds-select {
  display: block;
  width: 100%;
  height: 2.25rem;
  padding: 0 var(--space-3);
  font-family: inherit;
  font-size: var(--font-size-sm);
  color: var(--color-fg);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  transition:
    border-color var(--transition),
    box-shadow var(--transition);
}

.ds-textarea {
  height: auto;
  min-height: 5rem;
  padding: var(--space-2) var(--space-3);
  line-height: var(--line-height-normal);
  resize: vertical;
}

.ds-input::placeholder,
.ds-textarea::placeholder {
  color: var(--color-fg-subtle);
}

.ds-input:focus,
.ds-textarea:focus,
.ds-select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.ds-input:disabled,
.ds-textarea:disabled,
.ds-select:disabled {
  background: var(--color-bg-muted);
  color: var(--color-fg-muted);
  cursor: not-allowed;
}

/* --- Card --- */
.ds-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}

.ds-card-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-fg);
  margin: 0 0 var(--space-2);
}

.ds-card-body {
  font-size: var(--font-size-sm);
  color: var(--color-fg-muted);
  line-height: var(--line-height-normal);
}

/* --- Badge --- */
.ds-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.125rem var(--space-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  line-height: 1.25rem;
  border-radius: var(--radius-full);
  background: var(--color-bg-muted);
  color: var(--color-fg);
}

.ds-badge-primary {
  background: var(--color-primary-subtle);
  color: var(--color-primary);
}
.ds-badge-success {
  background: var(--color-success-subtle);
  color: var(--color-success);
}
.ds-badge-warning {
  background: var(--color-warning-subtle);
  color: var(--color-warning);
}
.ds-badge-danger {
  background: var(--color-danger-subtle);
  color: var(--color-danger);
}

/* --- Renk paleti gösterimi (sadece test sayfası) --- */
.ds-swatch {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-bg);
}

.ds-swatch-chip {
  width: 100%;
  height: 3rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
}

.ds-swatch-name {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-fg);
}

.ds-swatch-token {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--color-fg-muted);
}

/* --- Lucide ikon temel kuralları --- */
.lucide {
  display: inline-block;
  vertical-align: middle;
  width: 1.25rem;
  height: 1.25rem;
  stroke-width: 1.5;
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

.lucide-sm {
  width: 1rem;
  height: 1rem;
}
.lucide-lg {
  width: 1.5rem;
  height: 1.5rem;
}

/*
 * --- Phase 10 — Editör primitive'leri ---
 * Tek tasarım kaynağı kuralı gereği React editör burada tanımlanan
 * sınıfları kullanır. Ham CSS yazmak yerine, paylaşılan token'lardan
 * gelen değerlerle bileşen sınıfları kurulur.
 */

/* Buton boyut varyasyonları */
.ds-btn-sm {
  height: 1.75rem;
  padding: 0 var(--space-2);
  font-size: var(--font-size-xs);
  gap: var(--space-1);
}

.ds-btn-icon {
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  justify-content: center;
}

/* Separator */
.ds-separator {
  background: var(--color-border);
  flex-shrink: 0;
}
.ds-separator--horizontal {
  height: 1px;
  width: 100%;
  margin: var(--space-3) 0;
}
.ds-separator--vertical {
  width: 1px;
  height: 100%;
}

/* Tabs */
.ds-tabs-list {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: var(--color-bg-muted);
  padding: 4px;
  border-radius: var(--radius);
}
.ds-tabs-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  height: 1.75rem;
  padding: 0 var(--space-3);
  font-family: inherit;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-fg-muted);
  background: transparent;
  border: none;
  border-radius: calc(var(--radius) - 2px);
  cursor: pointer;
  transition:
    background var(--transition),
    color var(--transition);
}
.ds-tabs-trigger[data-state="active"] {
  background: var(--color-bg);
  color: var(--color-fg);
  box-shadow: var(--shadow-sm);
}
.ds-tabs-trigger:hover:not([data-state="active"]) {
  color: var(--color-fg);
}
.ds-tabs-content {
  margin-top: var(--space-3);
  outline: none;
}

/* Dialog */
.ds-dialog-overlay {
  position: fixed;
  inset: 0;
  background: rgb(15 23 42 / 50%);
  backdrop-filter: blur(2px);
  z-index: 50;
}
.ds-dialog-content {
  position: fixed;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  transform: translate(-50%, -50%);
  width: min(90vw, 32rem);
  max-height: 85vh;
  overflow: auto;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-5);
  z-index: 51;
}
.ds-dialog-close {
  position: absolute;
  inset-block-start: var(--space-3);
  inset-inline-end: var(--space-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--color-fg-muted);
  cursor: pointer;
  transition:
    background-color var(--transition),
    color var(--transition);
}
.ds-dialog-close:hover {
  background: var(--color-bg-muted);
  color: var(--color-fg);
}
.ds-dialog-title {
  margin: 0 0 var(--space-2);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-fg);
}
.ds-dialog-description {
  margin: 0 0 var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-fg-muted);
}

/* Tooltip */
.ds-tooltip {
  background: var(--color-fg);
  color: var(--color-bg);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  z-index: 60;
}

/* Menu (DropdownMenu) */
.ds-menu {
  min-width: 10rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  padding: var(--space-1);
  z-index: 55;
}
.ds-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-fg);
  border-radius: var(--radius-sm);
  cursor: pointer;
  outline: none;
  transition: background-color var(--transition);
}
.ds-menu-item[data-highlighted],
.ds-menu-item:hover {
  background: var(--color-bg-muted);
}
.ds-menu-item[data-disabled] {
  color: var(--color-fg-subtle);
  pointer-events: none;
}
.ds-menu-separator {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-1) 0;
}
.ds-menu-item--danger {
  color: var(--color-danger, #dc2626);
}
.ds-menu-item--danger[data-highlighted],
.ds-menu-item--danger:hover {
  background: var(--color-danger-bg, #fef2f2);
  color: var(--color-danger, #dc2626);
}
.ds-menu-item--sub-trigger {
  justify-content: space-between;
}
.ds-menu-item--sub-trigger[data-state="open"] {
  background: var(--color-bg-muted);
}
.ds-menu-item__chevron {
  margin-left: auto;
  opacity: 0.7;
}

/* Popover */
.ds-popover {
  min-width: 12rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  padding: var(--space-3);
  z-index: 55;
}

/* ========================================================================
   Phase 15 — Block style system defaults (ADR-0012).
   Tema CSS'i bu default'ları override edebilir; blok template'leri
   ``style="--<block>-pt:60px"`` gibi inline değişkenler enjekte eder.
   ======================================================================== */
:root {
  /* Spacing preset defaults */
  --spacing-none: 0;
  --spacing-compact: 1rem;
  --spacing-normal: 2.5rem;
  --spacing-spacious: 4rem;

  /* Heading scale defaults */
  --heading-xs: 0.875rem;
  --heading-sm: 1rem;
  --heading-md: 1.25rem;
  --heading-lg: 1.5rem;
  --heading-xl: 2rem;
  --heading-2xl: 2.75rem;
}

/* Site-data blok temel görünümü — tema bunları override eder. */
.contact-info,
.address-block,
.social-links,
.working-hours,
.company-identity,
.newsletter,
.footer-bottom,
.announcement-bar {
  padding-top: var(--block-pt, var(--spacing-normal));
  padding-bottom: var(--block-pb, var(--spacing-normal));
}

/* Mobil override cascade'i — desktop variable'a fallback. */
@media (max-width: 768px) {
  .contact-info,
  .address-block,
  .social-links,
  .working-hours,
  .company-identity,
  .newsletter,
  .footer-bottom,
  .announcement-bar {
    padding-top: var(--block-mobile-pt, var(--block-pt, var(--spacing-normal)));
    padding-bottom: var(--block-mobile-pb, var(--block-pb, var(--spacing-normal)));
  }
}

/* Site Data utility class'ları (Phase 18'de tema CSS'i zenginleştirir). */
.contact-info__list,
.social-links__list,
.footer-bottom__links {
  list-style: none;
  padding: 0;
  margin: 0;
}
.announcement-bar {
  padding: var(--space-2) var(--space-4);
  text-align: center;
}
.announcement-bar--info { background: var(--color-primary-subtle); }
.announcement-bar--warning { background: var(--color-warning-subtle, #fff7ed); }
.announcement-bar--promo { background: var(--color-success-subtle, #ecfdf5); }
.announcement-bar--alert { background: var(--color-danger-subtle, #fef2f2); }
.announcement-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  max-width: 1280px;
  margin: 0 auto;
}

/* Animation entry keyframes. */
@keyframes ds-anim-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes ds-anim-slide-up {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes ds-anim-slide-down {
  from { opacity: 0; transform: translateY(-16px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes ds-anim-zoom {
  from { opacity: 0; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1); }
}
.animate-fade { animation: ds-anim-fade var(--block-anim-duration, 500ms) ease both var(--block-anim-delay, 0ms); }
.animate-slide-up { animation: ds-anim-slide-up var(--block-anim-duration, 500ms) ease both var(--block-anim-delay, 0ms); }
.animate-slide-down { animation: ds-anim-slide-down var(--block-anim-duration, 500ms) ease both var(--block-anim-delay, 0ms); }
.animate-zoom { animation: ds-anim-zoom var(--block-anim-duration, 500ms) ease both var(--block-anim-delay, 0ms); }
