/* =================== Стеклянная кнопка =================== */
.glass-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 28px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #DAA520;
  background: rgba(218,165,32,0.12);
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  border-radius: 30px;
  border: 1px solid rgba(218,165,32,0.3);
  box-shadow: 0 4px 14px rgba(218,165,32,0.25);
  cursor: pointer;
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.3s ease;
  z-index: 10;
}
/* Emoji-fallback для Members Area (уроки, статьи) */
.ma-lesson__content, 
.ma-article__content, 
.ma-body, 
.t-text, 
.t-descr, 
body {
  font-family: "Montserrat", "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif !important;
}

/* Hover - легкое увеличение и подсветка */
.glass-button:hover {
  transform: scale(1.05);
  background: rgba(218,165,32,0.18);
  box-shadow: 0 6px 20px rgba(218,165,32,0.35);
}

/* Блик */
.glass-button::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.08), transparent 70%);
  mix-blend-mode: screen;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* Появление блика при наведении */
.glass-button:hover::after {
  opacity: 1;
}

/* Мягкая тряска */
@keyframes shakeButtonSoft {
  0% { transform: translate(0,0); }
  25% { transform: translate(-1px, 0.5px); }
  50% { transform: translate(1px, -0.5px); }
  75% { transform: translate(-0.5px, 0.5px); }
  100% { transform: translate(0,0); }
}

.shaking {
  animation: shakeButtonSoft 0.15s ease-in-out;
}


/* ---------- FORCE ROOT & WRAPPERS BACKGROUND (override) ---------- */
:root { --evo-dark: #272727; --evo-gold: #daa520; }

/* root/background */
html, body {
  margin: 0;
  padding: 0;
  width: 100%;
  min-height: 100%;
  background: var(--evo-dark) !important;
  color: #d8d8d8;
  overflow-x: hidden;
}

/* Make main site wrappers transparent and full width (Tilda wrappers safe-override) */
.evo-wrap, .t-site, .t-body, #allrecords, .t-records {
  background: transparent !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box;
}

/* If your theme has a centered container, break it out with this class */
.evo-full-bleed {
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;
  box-sizing: border-box;
  background: transparent;
}

/* Ensure header/footer/sections are allowed to extend edge-to-edge */
.evo-header, .evo-footer, main, section {
  width: 100% !important;
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Mobile safe: use CSS var for viewport height (set by JS below) */
.full-vh {
  min-height: calc(var(--vh, 1vh) * 100);
}

/* ================= Учет Safe Area для iPhone X/15 ================= */
body {
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
  box-sizing: border-box;
}



/* Подстраховка для Safari, где env() иногда не срабатывает */
@supports(padding: max(env(safe-area-inset-top), 0px)) {
  body {
    padding-top: max(env(safe-area-inset-top), 0px);
    padding-bottom: max(env(safe-area-inset-bottom), 0px);
    padding-left: max(env(safe-area-inset-left), 0px);
    padding-right: max(env(safe-area-inset-right), 0px);
  }

