/*
 * Kendin Tasarla – Mobil arayüz (neonledtabela.com.tr mantığı).
 * Masaüstü görünümü değiştirilmez.
 */

/* Arkaplan değiştirme UI kaldırıldı (desktop + mobile) */
.background-gallery,
.mobile-bg-button,
.mobile-bg-menu {
  display: none !important;
}

/* Path-length butonunun altına "Arkaplan Yükle" eklemek için stack */
#pathLengthInfo {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Masaüstü: cetvel + arkaplan yükle sağ alta */
@media (min-width: 769px) {
  .path-length-info,
  #pathLengthInfo {
    top: auto !important;
    left: auto !important;
    bottom: 1.25rem !important;
    right: auto !important;
    left: 1.25rem !important;
  }
}

.temp-bg-upload-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  height: 30px;
  padding: 0 0.45rem;
  border-radius: 10px;
  background: rgba(18, 18, 18, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.9);
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  backdrop-filter: blur(10px);
  box-sizing: border-box;
  max-width: min(150px, calc(100vw - 3.5rem));
  align-self: flex-start;
}

.mobile-bg-upload-btn {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  gap: 0.2rem;
  height: 24px;
  padding: 0 0.2rem;
  font-size: 0.62rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.08);
  border-radius: 5px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  cursor: pointer;
  margin-left: 0.35rem; /* kenardan içeri */
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box;
  max-width: min(140px, calc(100vw - 10.5rem));
}

.mobile-bg-upload-btn .material-icons {
  font-size: 13px;
  line-height: 1;
}

.temp-bg-upload-btn:hover {
  border-color: rgba(0, 255, 136, 0.25);
  background: rgba(0, 255, 136, 0.08);
  color: rgba(0, 255, 136, 0.95);
}

.temp-bg-upload-btn .material-icons {
  font-size: 16px;
  line-height: 1;
}

@media (max-width: 768px) {
  /* Mobil koyu palet: tek aile, uyumlu siyah/gri tonları */
  body {
    --mobile-bg: #0d0d0d;
    --mobile-surface: #141414;
    --mobile-elevated: #1a1a1a;
    --mobile-border: rgba(255, 255, 255, 0.08);
    background-color: var(--mobile-bg) !important;
    overflow: hidden;
    min-height: 100vh;
    min-height: 100dvh;
    padding-bottom: env(safe-area-inset-bottom, 0);
  }

  /* —— 2. Önizleme: fiyat barının hemen altında, ~45vh —— */
  .preview-container,
  #neon-capture-area {
    position: fixed !important;
    top: calc(44px + env(safe-area-inset-top, 0)) !important;
    left: 0 !important;
    width: 100% !important;
    height: 45vh !important;
    height: calc(45vh - 44px - env(safe-area-inset-top, 0)) !important;
    min-height: 200px !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
    border-bottom: 1px solid var(--mobile-border) !important;
    background-color: var(--mobile-bg) !important;
    z-index: 10 !important;
  }

  .preview-container .neon-svg,
  #svgPreview.neon-svg {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .preview-container .neon-svg svg,
  #svgPreview.neon-svg svg {
    transform-origin: 50% 50%;
    overflow: visible;
    max-width: 100%;
    max-height: 100%;
  }

  /* —— 3. Toolbar: ekranın altında, footer’ın hemen üstünde sabit (referans gibi) —— */
  .toolbar-container {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    top: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0.5rem 0.5rem !important;
    padding-left: calc(0.5rem + env(safe-area-inset-left, 0)) !important;
    padding-right: calc(0.5rem + env(safe-area-inset-right, 0)) !important;
    padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0)) !important;
    z-index: 90 !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    touch-action: manipulation !important;
    pointer-events: auto !important;
    border-radius: 0 !important;
    border-top: 1px solid var(--mobile-border) !important;
    background: var(--mobile-bg) !important;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  .toolbar-container::-webkit-scrollbar {
    display: none;
  }

  .toolbar-group {
    flex-wrap: nowrap !important;
    padding: 0.25rem 0 !important;
    gap: 0.25rem !important;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }
  .toolbar-group::-webkit-scrollbar {
    display: none;
  }
  .toolbar-group-header {
    display: none !important;
  }
  .toolbar-actions {
    flex-direction: row !important;
    flex-shrink: 0 !important;
    gap: 0.25rem !important;
    position: relative !important;
    padding-top: 16px !important; /* "TASARLA" etiketi için yer */
  }

  /* Alt bar etiketi: ikinci görseldeki gibi */
  .toolbar-actions::before {
    content: "TASARLA";
    position: absolute;
    top: -2px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: rgba(255, 255, 255, 0.55);
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.10);
    padding: 1px 7px;
    border-radius: 999px;
    pointer-events: none;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  .toolbar-btn {
    -webkit-tap-highlight-color: transparent !important;
    min-width: 40px !important;
    min-height: 40px !important;
    padding: 0.35rem 0.5rem !important;
    flex-direction: row !important;
    flex-shrink: 0 !important;
    touch-action: manipulation !important;
    cursor: pointer !important;
    border-radius: 12px !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(255, 255, 255, 0.06) !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.22) !important;
  }

  /* Butonları renklendir (sıra: Metin, Font, Ölçü, Kesim, Pleksi, Ekstralar) */
  .toolbar-actions .toolbar-btn:nth-child(1) { border-color: rgba(0, 255, 136, 0.22) !important; background: rgba(0, 255, 136, 0.08) !important; }
  .toolbar-actions .toolbar-btn:nth-child(2) { border-color: rgba(59, 130, 246, 0.22) !important; background: rgba(59, 130, 246, 0.08) !important; }
  .toolbar-actions .toolbar-btn:nth-child(3) { border-color: rgba(245, 158, 11, 0.22) !important; background: rgba(245, 158, 11, 0.08) !important; }
  .toolbar-actions .toolbar-btn:nth-child(4) { border-color: rgba(236, 72, 153, 0.22) !important; background: rgba(236, 72, 153, 0.08) !important; }
  .toolbar-actions .toolbar-btn:nth-child(5) { border-color: rgba(168, 85, 247, 0.22) !important; background: rgba(168, 85, 247, 0.08) !important; }
  .toolbar-actions .toolbar-btn:nth-child(6) { border-color: rgba(148, 163, 184, 0.22) !important; background: rgba(148, 163, 184, 0.08) !important; }

  .toolbar-actions .toolbar-btn:active {
    transform: translateY(1px) scale(0.98);
  }
  .toolbar-btn .material-icons {
    font-size: 1.1rem !important;
  }
  .toolbar-btn-label {
    display: none !important;
  }

  /* —— 4. Paneller: bottom sheet, ~60vh, yuvarlak üst köşe (referans gibi); kapalıyken ekran dışı —— */
  .side-panel {
    position: fixed !important;
    top: 40vh !important;
    left: 0 !important;
    right: 0 !important;
    bottom: auto !important;
    width: 100% !important;
    height: 60vh !important;
    height: calc(60vh + env(safe-area-inset-bottom, 0)) !important;
    max-height: none !important;
    padding: 0 !important;
    padding-top: 0.75rem !important;
    padding-left: calc(1.25rem + env(safe-area-inset-left, 0)) !important;
    padding-right: calc(1.25rem + env(safe-area-inset-right, 0)) !important;
    padding-bottom: calc(200px + env(safe-area-inset-bottom, 0)) !important;
    box-sizing: border-box !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    background: var(--mobile-surface) !important;
    border: none !important;
    border-radius: 25px 25px 0 0 !important;
    box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.35) !important;
    transition: transform 0.28s ease !important;
    right: -100% !important;
    pointer-events: none !important;
    visibility: hidden !important;
    z-index: 50 !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .side-panel.active,
  .side-panel[style*="display: block"],
  .side-panel[style*="display:block"] {
    right: 0 !important;
    pointer-events: auto !important;
    visibility: visible !important;
    transform: none !important;
  }
  .side-panel .panel-header {
    border-radius: 0 !important;
    padding: 0.5rem 0 !important;
  }
  .side-panel .panel-title {
    font-size: 0.875rem !important;
  }
  .side-panel .panel-close {
    display: none !important;
  }
  .side-panel .panel-body {
    padding: 1rem 0.75rem 1rem !important;
    padding-bottom: calc(7rem + 100px + env(safe-area-inset-bottom, 0)) !important;
    box-sizing: border-box !important;
  }
  /* Font paneli: en alttaki font kartları barın üstünde kalsın, seçilebilsin */
  #fontPanel #fontList {
    margin-bottom: 0 !important;
    padding-bottom: calc(4rem + 85px + env(safe-area-inset-bottom, 0)) !important;
  }
  .side-panel .panel-body > * {
    max-width: 100% !important;
  }
  .side-panel textarea,
  .side-panel input[type="text"],
  .side-panel #textInput {
    box-sizing: border-box !important;
    max-width: 100% !important;
  }
  .side-panel .textarea-wrapper,
  .side-panel #wordColorList,
  .side-panel #colorPicker,
  .side-panel #fontList {
    max-width: 100% !important;
  }
  /* Metin kutusu ile kelime kutucukları (Neon, Yazı) çakışmasın – araya belirgin boşluk */
  .side-panel .textarea-wrapper {
    margin-bottom: 2.5rem !important;
  }
  #textPanel .textarea-wrapper {
    margin-bottom: 1.75rem !important;
  }
  /* Mobilde Metin panelindeki açıklama paragraflarını kaldır (gereksiz, yer kaplıyor) */
  #textPanel .panel-body p {
    display: none !important;
  }
  #textPanel .panel-body .textarea-wrapper,
  #textPanel .textarea-neon-container {
    overflow: visible !important;
  }
  #textPanel #wordColorList {
    /* iPhone 12 Pro gibi daha kısa viewport'larda kelime listesi textarea'nın üstüne çıkabiliyor.
       Kesin çözüm: listeyi normal akışa zorla ve wrap'li flex yap. */
    position: static !important;
    inset: auto !important;
    transform: none !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
    margin-top: 0.5rem !important;
    margin-bottom: 1rem !important;
    min-height: 2.5rem !important;
    padding-top: 0 !important;
  }

  /* Textarea'nın yüksekliği cihazdan cihaza değişen panel yüksekliğinde çok küçülmesin */
  #textPanel .textarea-wrapper,
  .side-panel .textarea-wrapper {
    height: auto !important;
  }
  #textPanel #textInput {
    min-height: 120px !important;
    padding-bottom: 2.25rem !important;
  }
  /* Metin paneli: Renk Seçiniz gridinin en alt satırı barın üstünde kalsın, seçilebilsin */
  #textPanel #colorPicker {
    padding-bottom: calc(4rem + 88px + env(safe-area-inset-bottom, 0)) !important;
    position: relative !important;
    z-index: 5 !important;
    pointer-events: auto !important;
  }
  #textPanel #colorPicker * {
    pointer-events: auto !important;
  }
  /* iOS Safari: tap'in butona gitmesi için ekstra garanti */
  #textPanel #colorPicker .renkler,
  #textPanel #colorPicker button[data-color] {
    position: relative !important;
    z-index: 6 !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: transparent !important;
  }
  /* Dairenin kendisi event yakalamasın; tıklama butonda kalsın */
  #textPanel #colorPicker .renkler-dot {
    pointer-events: none !important;
  }
  /* Ölçü paneli: Satır Pozisyonları (#1 Neon, #2 Yazı) en altı barın üstünde kalsın */
  #sizePanel #linePositionsSection,
  #sizePanel #linePositionControls {
    padding-bottom: calc(4rem + 88px + env(safe-area-inset-bottom, 0)) !important;
  }

  /* Kelime butonları (Neon, Yazı) üzerindeki ipucu çizgisi ve kırmızı noktaları kaldır – birbirine girmesin */
  .hint-container,
  .hint-dot,
  .hint-cursor,
  body .hint-container,
  body .hint-dot,
  body .hint-cursor,
  #wordColorList .hint-container,
  #wordColorList .hint-dot,
  .word-item .hint-container,
  .word-item .hint-dot,
  .side-panel .hint-container,
  .side-panel .hint-dot,
  #textPanel .hint-container,
  #textPanel .hint-dot {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    position: absolute !important;
    left: -9999px !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    z-index: -1 !important;
  }
  /* Kelime butonları tıklanabilir ve ipucunun üstünde görünsün */
  #wordColorList {
    position: relative !important;
    z-index: 1 !important;
  }
  #wordColorList .word-item {
    position: relative !important;
    z-index: 2 !important;
  }

  /* Açık panelde metin girişi çalışsın */
  .side-panel.active input,
  .side-panel.active textarea,
  .side-panel.active [contenteditable],
  .side-panel[style*="display: block"] input,
  .side-panel[style*="display: block"] textarea,
  .side-panel[style*="display: block"] [contenteditable],
  .side-panel[style*="display:block"] input,
  .side-panel[style*="display:block"] textarea,
  .side-panel[style*="display:block"] [contenteditable] {
    -webkit-user-select: text !important;
    user-select: text !important;
    touch-action: manipulation !important;
  }

  /* —— 5. Fiyat + Sepete Ekle: mobilde en üstte, tek satır; fiyat solda, ufak buton sağda —— */
  .panel-footer,
  #panelFooter {
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0.25rem !important;
    padding: 0.5rem 1rem !important;
    min-height: 44px !important;
    background: var(--mobile-elevated) !important;
    border-radius: 0.75rem !important;
    border: 1px solid var(--mobile-border) !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35) !important;
  }
  #panelFooter .tahmini-tutar {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }
  #panelFooter .sepete-ekle-btn {
    flex: 0 0 auto !important;
  }
  /* Mobil: üst barda neon uzunluk butonu (cetvel ikonu + X m) */
  .mobile-neon-length-btn {
    flex-shrink: 0 !important;
    margin-right: 0.45rem !important;
    min-width: 2.75rem !important;
    height: 22px !important;
    padding: 0 0.2rem !important;
    border-radius: 4px !important;
  }
  body.panel-open .panel-footer,
  body.panel-open #panelFooter {
    transform: none !important;
  }
  .panel-footer .tahmini-tutar {
    font-size: 0.85rem !important;
    margin-bottom: 0 !important;
    flex: 0 0 auto !important;
    min-width: 6.75rem !important; /* 5-7 haneli fiyat + ₺ için yeterli */
    overflow: visible !important;
    white-space: nowrap !important;
    text-overflow: clip !important;
    margin-right: 0.4rem !important;
  }
  .panel-footer .tahmini-tutar .amount {
    font-size: 1rem !important;
    font-weight: 700 !important;
  }
  .panel-footer .sepete-ekle-btn {
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 32px !important;
    height: 32px !important;
    padding: 0 0.65rem !important;
    font-size: 0.73rem !important;
    font-weight: 600 !important;
    flex-shrink: 0 !important;
    border-radius: 6px !important;
    -webkit-tap-highlight-color: transparent !important;
    box-shadow: 0 0 8px rgba(74, 222, 128, 0.3) !important;
  }

  /* Sadece fiyat gösteren ayrı bar – mobil */
  #mobilePriceDisplay {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.35rem 1rem 0.45rem !important;
    margin-top: 1rem !important; /* Üst banttan daha uzak */
    background: rgba(12, 12, 12, 0.96) !important;
    border-top: 1px solid rgba(148, 163, 184, 0.35) !important;
    border-bottom: 1px solid rgba(15, 23, 42, 0.9) !important;
    color: #e5e7eb !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    z-index: 1 !important;
    border-radius: 0 0 0.75rem 0.75rem !important;
  }
  #mobilePriceDisplay::before {
    content: 'Fiyat:' !important;
    margin-right: 0.4rem !important;
    color: rgba(148, 163, 184, 0.9) !important;
    font-weight: 500 !important;
  }

  /* Path length / cetvel ikonu: üst sola safe area ile */
  .path-length-info,
  #pathLengthInfo {
    display: none !important; /* Mobilde tamamen gizle – fiyatın üzerine binmesin */
  }
  .fullscreen-button {
    top: calc(0.75rem + env(safe-area-inset-top, 0)) !important;
    right: calc(0.75rem + env(safe-area-inset-right, 0)) !important;
    z-index: 80 !important;
  }
}

/* Sepete ekle onay animasyonu (buton içinde tik + yeşil splash) */
.sepete-ekle-btn.cart-success {
  position: relative;
  overflow: hidden;
}
.sepete-ekle-btn .cart-success-tick {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: rgba(16, 185, 129, 1);
}
.sepete-ekle-btn .cart-splash {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 44px;
  height: 44px;
  transform: translate(-50%, -50%) scale(0.2);
  border-radius: 9999px;
  background: rgba(16, 185, 129, 0.25);
  border: 1px solid rgba(16, 185, 129, 0.35);
  opacity: 1;
  z-index: 1;
  animation: cartSplash 700ms ease-out forwards;
}
@keyframes cartSplash {
  0% {
    transform: translate(-50%, -50%) scale(0.2);
    opacity: 0.9;
  }
  60% {
    transform: translate(-50%, -50%) scale(1.06);
    opacity: 0.6;
  }
  100% {
    transform: translate(-50%, -50%) scale(1.25);
    opacity: 0;
  }
}
