/* ============================================================
   БАГАЧУУД ХҮНС — Custom Styles
   ============================================================ */

/* ---- Material Symbols ---- */
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  display: inline-block;
  line-height: 1;
}

/* ---- Utility ---- */
.hero-gradient {
  background: linear-gradient(135deg, rgba(0,78,186,.85) 0%, rgba(0,100,236,.6) 100%);
}
.glass-card {
  background: rgba(255,255,255,.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.3);
}
.nunito-tight      { letter-spacing: -.015em; line-height: 1.6; }
.headline-tracking { letter-spacing: -.025em; line-height: 1.15; }

/* ---- Mobile menu transition ---- */
#mobile-menu { transition: max-height .3s ease, opacity .3s ease; overflow: hidden; }
#mobile-menu.hidden { max-height: 0; opacity: 0; }

/* ---- Hero Slider ---- */
.slide        { display: none; }
.slide.active { display: block; }

/* ---- Notification bar ---- */
.notify-bar { animation: slideDown .4s ease; }
@keyframes slideDown {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}

/* ---- Order modal overlay ---- */
.modal-overlay { transition: opacity .25s ease; }

/* ---- Scroll reveal animation ---- */
.reveal         { opacity: 0; transform: translateY(30px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ---- Go to top button ---- */
#go-top      { opacity: 0; pointer-events: none; transform: translateY(12px); transition: opacity .3s ease, transform .3s ease; }
#go-top.show { opacity: 1; pointer-events: auto; transform: translateY(0); }

/* ---- Messenger FAB ---- */
#messenger-fab {
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px);
  transition: opacity .3s ease, transform .3s ease;
}
#messenger-fab.show {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
#messenger-fab:hover {
  transform: translateY(-3px) scale(1.07);
  box-shadow: 0 8px 28px rgba(0,153,255,.6) !important;
}
/* Always-visible on page load (fades in after 1 s) */
#messenger-fab.always {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
@keyframes messenger-pulse {
  0%, 100% { box-shadow: 0 4px 18px rgba(0,153,255,.45); }
  50%       { box-shadow: 0 4px 28px rgba(0,153,255,.8), 0 0 0 6px rgba(0,153,255,.15); }
}
#messenger-fab.always { animation: messenger-pulse 2.5s ease-in-out infinite; }

/* ---- News card — featured ---- */
.news-card-featured {
  border: 2px solid transparent;
  transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease;
}
.news-card-featured:hover {
  border-color: #0064EC;
  box-shadow: 0 20px 50px -10px rgba(0,100,236,.18);
  transform: translateY(-4px);
}

/* ---- News card — side ---- */
.news-card-side {
  border-left-width: 4px;
  border-color: #0064EC;
  border-top: 2px solid transparent;
  border-right: 2px solid transparent;
  border-bottom: 2px solid transparent;
  transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease;
}
.news-card-side:hover {
  border-left-width: 8px;
  transform: translateX(4px);
  transition: 200ms;
}

/* ---- Visit counter badge ---- */
.news-visit-count {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: #0064EC;
  background: rgba(0,100,236,.08);
  border-radius: 999px;
  padding: 3px 10px;
  letter-spacing: .04em;
}

/* ---- Hero slider dots — progress pill ---- */
.slider-dot { flex-shrink: 0; cursor: pointer; }
@keyframes dot-progress {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}
.dot-fill          { transform-origin: left; }
.dot-fill.running  { animation: dot-progress 6s linear forwards; }

/* ---- Partner slider dots ---- */
.partner-dot {
  flex-shrink: 0;
  cursor: pointer;
  height: 8px;
  transition: width .3s ease, background .3s ease;
}
