/* =================================================================== */
/* TOMB-PRAYERS.CSS - نسخه نهایی و کاملاً مستند شده                    */
/* =================================================================== */

.grid3 {
  grid-template-columns: 1fr;
  place-items: center;
  margin-left: 0 !important;
}

@media (min-width: 1200px) {
  .grid3 {
    grid-template-columns: 300px 300px;
    gap: 50px;
    justify-content: start;
  }
}

.custom-square {
  width: 120px;
  height: 120px;
  background-color: var(--color-white-aqua);
  border-radius: 8px;
  margin-bottom: 50px;
}

.custom-square.card {
    border: none;
}

.window {
  /* border-radius: 0.375rem; */
  display: flex;
  justify-content: center;
  align-items: center;
}

.salavat img,
.fatehe img {
  width: 30px;
  height: 30px;
}

.form-label-prayers {
  font-size: 0.875rem;
  font-weight: bold;
  margin-bottom: 0;
}

.prayer-counter-display {
  font-size: 1.25rem;
  font-weight: bold;
  color: var(--color-primary-hover);
  background-color: transparent;
  border: none;
  padding-top: 10px !important;
}

.text-label-counter-prayers {
  font-size: 0.625rem;
  color: var(--color-primary-hover);
  text-align: center;
  margin-bottom: 5px;
}

.form-control-prayers {
  padding: 0 12px;
  border-radius: 0;
}

.form-control-prayers:focus,
.form-control-prayers:active {
  border: none;
  box-shadow: none;
  outline: none;
  background-color: transparent;
  color: var(--color-primary-hover);
}
.w-40px {
  width: 30px;
  flex-shrink: 0;
}

.h-38px {
  height: 40px;
}

.custom-gap {
  gap: 2px;
}

.custom-padding {
  padding-left: 9px;
  padding-right: 9px;
}

/* افزایش عرض دکمه‌ها در صفحات بزرگتر (اصلاح شما) */
@media (min-width: 992px) {
  .w-40px {
    width: 40px;
  }
}

.prayer-send-btn,
.prayer-send-btn:hover,
.prayer-send-btn:disabled,
.prayer-send-btn:focus {
  background-color: var(--color-white-soft);
  color: var(--color-black-soft);
  border: none !important;
  font-size: 0.625rem;
  opacity: 1;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/*
 * تب نوا: دکمهٔ پخش مخفی است — استایل‌های زیر برای همان دکمهٔ d.none (در صورت نیاز)؛ فیلد کشویی عریض: .nova-dropdown-field-wide
 */
body.nova-page .prayer-send-btn.prayer-nova-play-btn:not(.nova-play-btn-interacted),
body.nova-page .prayer-send-btn.prayer-nova-play-btn:not(.nova-play-btn-interacted):hover,
body.nova-page .prayer-send-btn.prayer-nova-play-btn:not(.nova-play-btn-interacted):focus,
body.nova-page .prayer-send-btn.prayer-nova-play-btn:not(.nova-play-btn-interacted):active {
  background-color: var(--color-white-soft) !important;
  color: var(--color-black-soft) !important;
  border-color: transparent !important;
  transform: none !important;
  box-shadow: none !important;
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn:not(.nova-play-btn-interacted) i {
  color: var(--color-black-soft) !important;
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted {
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.08s ease, opacity 0.2s ease;
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted i {
  transition: color 0.2s ease, transform 0.08s ease;
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted:hover:not(:disabled) {
  background-color: var(--color-white-aqua) !important;
  color: var(--color-primary-hover) !important;
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted:hover:not(:disabled) i {
  color: var(--color-primary-hover);
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted:active:not(:disabled) {
  background-color: var(--color-white-warm) !important;
  color: var(--color-primary) !important;
  transform: scale(0.92) !important;
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted:active:not(:disabled) i {
  color: var(--color-primary);
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted:focus-visible:not(:disabled) {
  outline: 2px solid var(--color-primary-hover);
  outline-offset: 2px;
  box-shadow: none !important;
}

body.nova-page .prayer-send-btn.prayer-nova-play-btn.nova-play-btn-interacted:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}

.prayer-number-input {
  appearance: textfield;
  -moz-appearance: textfield;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: var(--color-black-soft);
}

.prayer-number-input::-webkit-outer-spin-button,
.prayer-number-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.prayer-number-input:focus,
.prayer-number-input:active{
  background-color: var(--color-white-soft);
  color: var(--color-black-soft);
}

.btn-prayers {
  border-radius: 0;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.btn-prayers i {
  font-size: 0.75rem;
}

.window .prayer-adjust-btn {
  height: 19px !important;
  background-color: var(--color-white-soft);
}

.window-description-prayer {
  margin-top: 5px;
  font-size: .625rem;
  color: var(--color-gray-mid);
  text-align: center;
}

.prayer-counter-wrapper {
  position: relative;
}

/* وقتی منوی کشویی ادعیه باز است، کارت روی هم‌ردیف‌ها و لایه‌های پایین‌تر قرار بگیرد */
.prayer-counter-wrapper.dropdown-open {
  z-index: 100;
}

/* --- استایل پایه برای کادر پیام --- */
.prayer-validation-message {
  position: absolute;
  top: 100%;
  left: 50%;
  width: 95%;
  padding: 6px 8px;
  background-color: var(--color-white-soft);
  font-size: 0.75rem;
  text-align: center;
  z-index: 10;
  opacity: 0;
  visibility: hidden;
  transform: translate(-50%, -10px);
  border-radius: 4px;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.prayer-validation-message.visible {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0);
}

/* --- استایل برای پیام خطا (قرمز) --- */
.prayer-validation-message.prayer-error-message {
  color: #dc3545; /* رنگ فونت خطا */
}

/* --- استایل برای پیام موفقیت (سبز) --- */
.prayer-validation-message.prayer-success-message {
  color: #198754; /* رنگ فونت موفقیت */
}
.prayer-validation-message.prayer-success-message:hover {
  color: #146c43; /* رنگ هاور فونت موفقیت */
}



/* Media Queries for responsive adjustments */
/* === Media Queries for responsive adjustments - Synced with tomb-share.css === */

/* Mobile layout: < 576px */
@media (max-width: 575.98px) {
  .grid3 {
    grid-template-columns: 1fr 1fr;
    gap: 15px;
  }

  .prayer-counter-wrapper,
  .custom-square {
    width: 100%;
    margin-bottom: 0;
  }

  .custom-square {
    width: 100% !important;
    height: 200px !important; /* Synced from share.css */
    margin-top: 20px;        /* Synced from share.css */
    margin-bottom: 20px;     /* Synced from share.css */
  }

  .custom-padding {
    padding-left: 0;
    padding-right: 0;
  }
}

/* Small tablet layout: 576px to 767.98px */
@media (min-width: 576px) and (max-width: 767.98px) {
  .grid3 {
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    padding-left: 10px;
  }

  .prayer-counter-wrapper,
  .custom-square {
    width: 100%;
    margin-bottom: 0;
  }

  .custom-square {
    width: 100% !important;
    height: 200px !important; /* Synced from share.css */
    margin-top: 30px;        /* Synced from share.css */
    margin-bottom: 60px;     /* Synced from share.css */
  }

  .custom-padding {
    padding-left: 0;
    padding-right: 0;
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {
  .custom-square {
    width: 180px;
    height: 270px;
  }

  .salavat img,
  .fatehe img {
    width: 50px;
    height: 50px;
    /* margin-bottom: 20px; */
  }

  .form-label-prayers {
    font-size: 1rem;
  }

  .custom-padding {
    padding-left: 0;
    padding-right: 0;
  }
}

@media (min-width: 992px) and (max-width: 1199.98px) {
  .custom-square {
    width: 220px;
    height: 220px;
  }

  .salavat img,
  .fatehe img {
    width: 50px;
    height: 50px;
    /* margin-bottom: 15px; */
  }

  .form-label-prayers {
    font-size: 1rem;
  }

  .prayer-counter-display {
    font-size: 1.25rem;
  }
}

@media (min-width: 1200px) {
  .custom-square {
    width: 300px;
    height: 300px;
  }

  .salavat img,
  .fatehe img {
    width: 90px;
    height: 90px;
    /* margin-bottom: 10px; */
  }

  .form-label-prayers {
    font-size: 1.25rem;
  }

  .prayer-counter-display {
    font-size: 1.5rem;
  }
}

/* --- استایل برای منوی کشویی ادعیه --- */
.prayer-dropdown {
    height: 100%;
    border: none;
    border-radius: 0;
    font-size: 0.75rem;
    background-color: var(--color-white-soft);
    color: var(--color-black-soft);
    box-shadow: none !important;
    outline: none !important;
    padding: 0 8px;
    cursor: pointer;
}

.prayer-dropdown:focus {
    border-color: transparent;
    box-shadow: none;
}

/* --- استایل اصلاح شده برای بخش ادعیه --- */

/* ۱. استایل باکس جدید برای آیکون دراپ‌داون */
.dua-icon-box {
    background-color: var(--color-white-soft);
    /* کلاس .window از قبل آیکون را وسط‌چین می‌کند */
}

.dua-icon-box i {
    font-size: 0.75rem;
    color: var(--color-black-soft);
}

/* ۲. حذف آیکون پیش‌فرض از خود منوی کشویی */
.prayer-dropdown {
    /* این خط آیکون بوت‌استرپ را حذف می‌کند */
    background-image: none !important;

    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;

    /* حفظ استایل‌های قبلی */
    height: 100%;
    border: none;
    border-radius: 0;
    font-size: 0.75rem;
    background-color: var(--color-white-soft);
    color: var(--color-black-soft);
    box-shadow: none !important;
    outline: none !important;
    padding: 0 8px;
    cursor: pointer;
}

.prayer-dropdown:focus {
    border-color: transparent;
    box-shadow: none;
}

.dua-icon-box {
    background-color: var(--color-white-soft);
    cursor: pointer; /* اضافه شد: برای نمایش حالت کلیک‌پذیر */
}

/* --- استایل‌های جدید برای منوی کشویی سفارشی (ادعیه) --- */

/* کانتینر اصلی برای موقعیت‌دهی صحیح لیست گزینه‌ها */
.custom-dropdown-wrapper {
  position: relative;
  height: 38px;
}

/* استایل دکمه اصلی که جایگزین select شده است */
.custom-dropdown-trigger {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  border: none;
  background-color: transparent;
  padding: 0;
  text-align: start; /* برای زبان‌های راست‌چین */
  cursor: pointer;
}

/* استایل بخش آیکون در دکمه */
.custom-dropdown-trigger .dua-icon-box {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 100%;
  flex-shrink: 0;
  background-color: var(--color-white-soft);
}

/* استایل بخش متن در دکمه */
.custom-dropdown-trigger .custom-dropdown-label-wrapper {
  display: flex;
  align-items: center;
  flex-grow: 1;
  height: 100%;
  padding: 0 8px;
  background-color: var(--color-white-soft);
}

#dua2DropdownLabel {
  font-size: 0.75rem;
  color: var(--color-black-soft);
}

/* استایل لیست گزینه‌ها */
.custom-dropdown-options {
  display: none; /* در حالت عادی مخفی است */
  position: absolute;
  top: 105%; /* کمی فاصله از دکمه اصلی */
  left: 0;
  width: 100%;
  background-color: var(--color-white-soft);
  border: 1px solid var(--color-gray-mid);
  border-radius: 4px;
  list-style: none;
  padding: 4px 0;
  margin: 0;
  max-height: 200px;
  overflow-y: auto;
  z-index: 1001;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

/* استایل هر یک از گزینه‌ها */
.custom-dropdown-options li {
  padding: 8px 12px;
  font-size: 0.75rem;
  color: var(--color-black-soft);
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.custom-dropdown-options li:hover {
  background-color: var(--color-primary);
  color: #fff;
}

/* --- استایل‌های جدید برای منوی کشویی سفارشی (حفظ ظاهر اصلی) --- */

/* کانتینر اصلی برای موقعیت‌دهی صحیح لیست گزینه‌ها */
.custom-dropdown-container {
  position: relative;
}

/* استایل نمایشگر متن که دقیقاً شبیه select اصلی است */
#dua2DropdownDisplay,
#novaMazhabiDropdownDisplay,
#novaMonasebatiDropdownDisplay {
  display: flex; 
  align-items: center;     /* این خط برای وسط‌چینی عمودی است */
  justify-content: center; /* این خط جدید برای وسط‌چینی افقی اضافه شد */
  width: 100%;
  height: 100%;
  cursor: pointer; 
}

/* استایل لیست گزینه‌ها */
/* استایل لیست گزینه‌ها با اولویت بالا برای حذف قطعی اسکرول */
.prayer-counter-wrapper .custom-dropdown-options {
  display: none; 
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  background-color: var(--color-white-soft);
  border: 1px solid var(--color-gray-mid);
  border-radius: 4px;
  list-style: none;
  padding: 4px 0;
  margin: 0;
  z-index: 1001;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);

  /* --- دستورات کلیدی برای حذف محدودیت ارتفاع --- */
  height: auto !important;
  max-height: none !important;
  overflow-y: visible !important;
}

/* استایل هر یک از گزینه‌ها */
.custom-dropdown-options li {
  padding: 3px 12px;
  font-size: 0.75rem;
  color: var(--color-black-soft);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.custom-dropdown-options li:hover {
  background-color: var(--color-white-aqua);
  color: var(--color-black-soft);
}

/* --- استایل دکمه پخش صدا --- */

/* ۱. تنظیم موقعیت نسبی برای کارت‌ها تا دکمه بتواند داخل آن جا بگیرد */
.custom-square {
    position: relative; /* بسیار مهم برای قرارگیری دکمه در گوشه */
}

/* ۲. استایل دکمه بلندگو */
.audio-control-btn {
    position: absolute;
    top: 10px;
    left: 10px; /* گوشه سمت چپ بالا */
    background: transparent;
    border: none;
    color: #adb5bd; /* رنگ طوسی برای حالت خاموش */
    font-size: 1.2rem;
    cursor: pointer;
    z-index: 10;
    transition: all 0.3s ease;
    padding: 5px;
    line-height: 1;
}

/* ۳. حالت هاور (وقتی موس روی آن می‌رود) */
.audio-control-btn:hover {
    color: var(--color-primary); /* تغییر رنگ هنگام هاور */
    transform: scale(1.1);
}

/* ۴. حالت فعال (در حال پخش) */
.audio-control-btn.playing {
    color: #198754; /* رنگ سبز یا رنگ اصلی سایت */
    animation: pulse-audio 1.5s infinite;
}

/* انیمیشن تپش برای وقتی که صدا پخش می‌شود */
@keyframes pulse-audio {
    0% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.15); opacity: 0.8; }
    100% { transform: scale(1); opacity: 1; }
}

/* تب ادای احترام: ردیف عنوان نامرئی (هم‌ارتفاع) در هر دو کارت */
.respect-page .card.custom-square.fatehe .respect-flower-label-spacer,
.respect-page .card.custom-square.salavat .respect-flower-label-spacer {
  margin-top: 5px;
  visibility: hidden;
  user-select: none;
  pointer-events: none;
  margin-bottom: 0;
}

/* هر دو کارت: فضای پایین یکسان؛ دکمه روی بلاک نامرئی */
.respect-page .card.custom-square.fatehe .respect-flower-bottom-slot,
.respect-page .card.custom-square.salavat .respect-flower-bottom-slot {
  position: relative;
  width: 100%;
  flex-shrink: 0;
}

.respect-page .card.custom-square.fatehe .respect-flower-bottom-spacer,
.respect-page .card.custom-square.salavat .respect-flower-bottom-spacer {
  visibility: hidden;
  pointer-events: none;
  user-select: none;
}

.respect-page .card.custom-square.fatehe .respect-flower-spacer-fake,
.respect-page .card.custom-square.salavat .respect-flower-spacer-fake {
  min-height: 0;
}

.respect-page .card.custom-square.fatehe .respect-flower-submit-overlay,
.respect-page .card.custom-square.salavat .respect-flower-submit-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.respect-page .card.custom-square.fatehe .respect-flower-submit-overlay .custom-btn-condolence-message,
.respect-page .card.custom-square.salavat .respect-flower-submit-overlay .custom-btn-condolence-message {
  pointer-events: auto;
  margin-bottom: 0;
  width: calc(100% - 20px);
  max-width: calc(100% - 20px);
}

/* ادای احترام: بلوک عدد + زیرنویس ۳۰px بالاتر (هر دو کارت، هم‌تراز با هم) */
.respect-page .card.custom-square.fatehe > .flex-grow-1,
.respect-page .card.custom-square.salavat > .flex-grow-1 {
  transform: translateY(-30px);
  margin-bottom: -30px;
}

/* تب نوا: عنوان‌های «نوای مذهبی» و «نوای مناسبتی» ۳۰px پایین‌تر از تصویر */
.nova-page .card.custom-square.fatehe > .form-label-prayers,
.nova-page .card.custom-square.salavat > .form-label-prayers {
  margin-top: 30px;
}

/* تب نوا: منوی «انتخاب کنید» مثل کارت ادعیه — لیست برش نخورد و بلوک نامرئی کلیک را نگیرد */
.nova-page .prayer-counter-wrapper {
  overflow: visible;
}

.nova-page .card.custom-square.fatehe,
.nova-page .card.custom-square.salavat {
  overflow: visible;
}

.nova-page .card.custom-square.fatehe > .flex-grow-1.invisible,
.nova-page .card.custom-square.salavat > .flex-grow-1.invisible {
  pointer-events: none;
}

.nova-page .prayer-counter-wrapper .custom-dropdown-container {
  position: relative;
  z-index: 2;
}

/* تب نوا: نوار سفید — جدا از فیلد با gap؛ 10px به بالا جابه‌جا */
body.nova-page .nova-dropdown-field-stack {
  gap: 10px;
}

body.nova-page .nova-field-above-placeholder {
  flex-shrink: 0;
  margin-top: -10px;
  background-color: var(--color-white-soft);
  border-radius: 6px;
  box-sizing: border-box;
}

/* تب نوا: فیلد «انتخاب کنید» — با جداییش از نوار بالا، گوشه‌های بیرونی کامل */
body.nova-page .prayer-dropdown-row .nova-dropdown-field-wide .prayer-dropdown {
  border-radius: 0;
  border-top-left-radius: 6px;
  border-bottom-left-radius: 6px;
}

body.nova-page .prayer-dropdown-row .nova-dropdown-field-wide .custom-dropdown-options {
  border-radius: 0;
  border-bottom-left-radius: 6px;
  border-bottom-right-radius: 6px;
}

/* تب نوا: باکس فلش */
body.nova-page .prayer-dropdown-row .dua-icon-box {
  border-radius: 0;
  border-top-right-radius: 6px;
  border-bottom-right-radius: 6px;
}

/*
 * ردیف «انتخاب کنید» (prayers): همان فاصله از کارت.
 * تب نوا: بلوک nova-dropdown-field-stack شامل نوار سفید + ردیف فیلد است.
 */
.prayer-counter-wrapper .card.custom-square .prayer-dropdown-row {
  position: absolute;
  bottom: calc(1rem + 9px);
  left: 1rem;
  right: 1rem;
  width: auto !important;
  max-width: none;
  margin: 0 !important;
  z-index: 4;
  box-sizing: border-box;
}

body.nova-page .prayer-counter-wrapper .card.custom-square .prayer-dropdown-row {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  z-index: auto;
  width: 100% !important;
}

/* صفحهٔ فاتحه و صلوات: ردیف کشویی ادعیه در جریان flex مثل فاتحه/صلوات/قرآن تا عدد و زیرنویس هم‌ارتفاع بماند */
body.prayers-page .prayer-counter-wrapper .card.custom-square .prayer-dropdown-row {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  z-index: auto;
  width: 100% !important;
  margin: 0 !important;
}

body.prayers-page .prayer-counter-wrapper {
  overflow: visible;
}

body.prayers-page .card.custom-square.prayer-card-dua {
  overflow: visible;
}

.prayer-counter-wrapper .card.custom-square .nova-dropdown-field-stack {
  position: absolute;
  bottom: calc(1rem + 9px);
  left: 1rem;
  right: 1rem;
  width: auto !important;
  max-width: none;
  margin: 0 !important;
  z-index: 4;
  box-sizing: border-box;
}

@media (max-width: 991.98px) {
  .prayer-counter-wrapper .card.custom-square .prayer-dropdown-row {
    bottom: 1rem;
  }

  .prayer-counter-wrapper .card.custom-square .nova-dropdown-field-stack {
    bottom: 1rem;
  }
}