/* ═══════════════════════════════════════════════════════════════
   AGATA DESIGN SYSTEM — глобальные токены и унификация
   Загружается ПОСЛЕ main.css — намеренно переопределяет устаревшие
   React/Vite стили и добавляет недостающие компоненты.
═══════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────
   1. CSS TOKENS (Design Variables)
───────────────────────────────────────────────────────────── */
:root {
  /* Palette */
  --c-gold:        #d4af37;
  --c-gold-light:  #f0c84a;
  --c-gold-dim:    rgba(212,175,55,.28);
  --c-gold-glow:   rgba(212,175,55,.10);
  --c-gold-border: rgba(212,175,55,.18);

  --c-bg:          #050505;
  --c-surface:     #0d0d1a;
  --c-surface-2:   #121220;
  --c-surface-3:   #1a1a2e;

  --c-border:      rgba(212,175,55,.15);
  --c-border-2:    rgba(255,255,255,.06);
  --c-border-3:    rgba(255,255,255,.03);

  --c-text:        #d4d4d4;
  --c-text-dim:    #888;
  --c-text-muted:  #555;
  --c-text-bright: #f0ead8;

  /* Type scale */
  --fz-xs:   0.72rem;
  --fz-sm:   0.85rem;
  --fz-base: 0.95rem;
  --fz-md:   1.05rem;
  --fz-lg:   1.25rem;
  --fz-xl:   1.6rem;
  --fz-2xl:  2.2rem;
  --fz-3xl:  3rem;

  /* Spacing */
  --sp-1: 4px;   --sp-2: 8px;   --sp-3: 12px;  --sp-4: 16px;
  --sp-5: 20px;  --sp-6: 24px;  --sp-8: 32px;  --sp-10: 40px;
  --sp-12: 48px; --sp-16: 64px;

  /* Radius */
  --r-xs:   3px;
  --r-sm:   6px;
  --r-md:   10px;
  --r-lg:   14px;
  --r-xl:   18px;
  --r-2xl:  24px;
  --r-pill: 100px;

  /* Easing */
  --ease-out:    cubic-bezier(.22,.68,0,1.2);
  --ease-smooth: cubic-bezier(.4,0,.2,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  /* Transition presets */
  --tr-fast:   0.15s var(--ease-smooth);
  --tr-base:   0.25s var(--ease-smooth);
  --tr-slow:   0.4s var(--ease-smooth);

  /* Shadows */
  --shadow-sm:  0 2px 8px rgba(0,0,0,.4);
  --shadow-md:  0 6px 24px rgba(0,0,0,.5);
  --shadow-lg:  0 16px 48px rgba(0,0,0,.6);
  --shadow-gold: 0 0 24px rgba(212,175,55,.18);
}

/* ─────────────────────────────────────────────────────────────
   2. RESET — убираем остатки Vite/React шаблона из main.css
───────────────────────────────────────────────────────────── */
:root {
  font-family: 'Montserrat', sans-serif;
  color-scheme: dark;
}

/* Убиваем синий #646cff из React */
a { color: inherit; text-decoration: none; }
a:hover { color: inherit; }
button:hover { border-color: transparent; }
button:focus-visible { outline: 2px solid var(--c-gold); outline-offset: 3px; }

/* ─────────────────────────────────────────────────────────────
   2b. BREADCRUMBS CONTAINER — отступ под fixed header (70px)
       Только breadcrumbs-container получает padding-top.
       Hero-секции управляют своим отступом самостоятельно.
───────────────────────────────────────────────────────────── */
.breadcrumbs-container {
  padding-top: 72px !important;  /* высота header */
}

/* ─────────────────────────────────────────────────────────────
   3. HEADER — всегда видим, без скачка при загрузке
───────────────────────────────────────────────────────────── */
.header {
  background: rgba(5,5,5,.92) !important;
  border-bottom: 1px solid rgba(212,175,55,.10) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}
.header.scrolled {
  background: rgba(7,5,18,.97) !important;
  border-bottom-color: rgba(212,175,55,.32) !important;
  box-shadow: 0 4px 28px rgba(0,0,0,.55) !important;
}

/* Активная ссылка навигации */
.nav-menu a.nav-active {
  color: var(--c-gold) !important;
}
.nav-menu a.nav-active::after {
  width: 100% !important;
}

/* ─────────────────────────────────────────────────────────────
   4. BREADCRUMBS — были в HTML, но без CSS
───────────────────────────────────────────────────────────── */
.breadcrumbs-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: .55rem 2rem;
  opacity: .85;
}

.breadcrumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 2px;
  list-style: none;
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  padding: 0; margin: 0;
  letter-spacing: .03em;
}

.breadcrumbs li a {
  color: var(--c-text-dim);
  transition: color var(--tr-fast);
  padding: 2px 4px;
  border-radius: var(--r-xs);
}
.breadcrumbs li a:hover { color: var(--c-gold); }

.breadcrumbs .separator {
  opacity: .35;
  font-size: .8em;
  margin: 0 1px;
  user-select: none;
}
.breadcrumbs .current {
  color: var(--c-gold);
  font-weight: 500;
}

/* ─────────────────────────────────────────────────────────────
   5. BUTTON SYSTEM — сводим к 3 чётким вариантам
───────────────────────────────────────────────────────────── */

/* Utility mixin-like base */
.btn, [class^="btn-g-"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: var(--fz-sm);
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: var(--r-md);
  cursor: pointer;
  transition:
    opacity var(--tr-fast),
    transform var(--tr-fast),
    box-shadow var(--tr-base),
    background var(--tr-fast),
    border-color var(--tr-fast);
  text-decoration: none;
  white-space: nowrap;
  user-select: none;
}

/* Primary — gold fill */
.btn-g-primary {
  background: linear-gradient(135deg, var(--c-gold), #b8952a);
  color: #050505;
  border: none;
  padding: .8rem 1.8rem;
  box-shadow: 0 4px 16px rgba(212,175,55,.25);
}
.btn-g-primary:hover {
  opacity: .88;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(212,175,55,.4);
  color: #050505;
}
.btn-g-primary:active { transform: translateY(0); opacity: 1; }

/* Secondary — outlined */
.btn-g-outline {
  background: transparent;
  color: var(--c-gold);
  border: 1px solid var(--c-gold-dim);
  padding: .75rem 1.6rem;
}
.btn-g-outline:hover {
  background: var(--c-gold-glow);
  border-color: rgba(212,175,55,.5);
  transform: translateY(-1px);
  color: var(--c-gold);
}

/* Ghost — subtle */
.btn-g-ghost {
  background: transparent;
  color: var(--c-text-dim);
  border: none;
  padding: .6rem 1.2rem;
}
.btn-g-ghost:hover {
  color: var(--c-gold);
  background: var(--c-gold-glow);
}

/* Small size modifier */
.btn-g-sm { font-size: var(--fz-xs) !important; padding: .5rem 1rem !important; }

/* ─────────────────────────────────────────────────────────────
   6. FOCUS INDICATORS — клавиатурная навигация
───────────────────────────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--c-gold) !important;
  outline-offset: 3px !important;
  border-radius: var(--r-xs) !important;
}

/* ─────────────────────────────────────────────────────────────
   7. MODAL — flex centering + плавная анимация
───────────────────────────────────────────────────────────── */
.modal {
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  /* фоновое затемнение */
  background: rgba(0,0,0,.72);
  opacity: 0;
  transition: opacity .22s ease;
}
/* display:flex задаётся в JS, затем добавляется .open */
.modal.open {
  opacity: 1;
}
/* обратная совместимость: если где-то ещё display:block */
.modal[style*="display: block"] {
  display: flex !important;
  opacity: 1;
}
.modal-content {
  margin: 0 !important;
  max-height: 90vh;
  overflow-y: auto;
  transform: scale(.93) translateY(14px);
  transition: transform .25s var(--ease-spring), opacity .25s ease;
  opacity: 0;
}
.modal.open .modal-content {
  transform: scale(1) translateY(0);
  opacity: 1;
}
@keyframes modalIn {
  from { opacity: 0; transform: scale(.93) translateY(12px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* ─────────────────────────────────────────────────────────────
   8. INPUT SYSTEM — унифицированный фокус
───────────────────────────────────────────────────────────── */
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="number"],
input[type="search"],
input[type="password"],
textarea,
select {
  font-family: 'Montserrat', sans-serif;
  transition: border-color var(--tr-fast), box-shadow var(--tr-fast);
}
input:focus, input:focus-visible,
textarea:focus, textarea:focus-visible,
select:focus, select:focus-visible {
  outline: none !important;
  border-color: var(--c-gold) !important;
  box-shadow: 0 0 0 3px rgba(212,175,55,.14) !important;
}

/* ─────────────────────────────────────────────────────────────
   9. CARD BASE SYSTEM
───────────────────────────────────────────────────────────── */
.card-sys {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  transition:
    border-color var(--tr-base),
    box-shadow var(--tr-base),
    transform var(--tr-base);
}
.card-sys:hover {
  border-color: var(--c-gold-dim);
  box-shadow: var(--shadow-md), 0 0 0 1px var(--c-gold-border);
  transform: translateY(-3px);
}

/* ─────────────────────────────────────────────────────────────
   10. SCROLL REVEAL ANIMATION
───────────────────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition:
    opacity .65s var(--ease-smooth),
    transform .65s var(--ease-smooth);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal[data-delay="1"] { transition-delay: .1s; }
.reveal[data-delay="2"] { transition-delay: .2s; }
.reveal[data-delay="3"] { transition-delay: .3s; }
.reveal[data-delay="4"] { transition-delay: .4s; }
.reveal[data-delay="5"] { transition-delay: .5s; }

/* ─────────────────────────────────────────────────────────────
   11. PAGE ENTRY — плавное появление страницы
───────────────────────────────────────────────────────────── */
main {
  animation: pageIn .45s var(--ease-smooth) both;
}
@keyframes pageIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─────────────────────────────────────────────────────────────
   12. SECTION TITLES — единый стиль
───────────────────────────────────────────────────────────── */
.ds-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.6rem, 4.5vw, 2.6rem);
  font-weight: 600;
  color: var(--c-text-bright);
  text-align: center;
  line-height: 1.2;
  letter-spacing: .04em;
  margin-bottom: .4rem;
}
.ds-sub {
  text-align: center;
  color: var(--c-text-dim);
  font-size: var(--fz-sm);
  max-width: 520px;
  margin: 0 auto 2.5rem;
  line-height: 1.7;
}
.ds-divider {
  display: block;
  width: 52px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--c-gold), transparent);
  margin: 1rem auto 2rem;
}

/* ─────────────────────────────────────────────────────────────
   13. EMPTY STATE
───────────────────────────────────────────────────────────── */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  text-align: center;
  color: var(--c-text-muted);
}
.empty-state__icon {
  font-size: 3.5rem;
  margin-bottom: 1.2rem;
  opacity: .45;
}
.empty-state__title {
  font-family: 'Cormorant Garamond', serif;
  font-size: var(--fz-xl);
  color: var(--c-text-dim);
  margin-bottom: .5rem;
}
.empty-state__text {
  font-size: var(--fz-sm);
  max-width: 340px;
}

/* ─────────────────────────────────────────────────────────────
   14. FOOTER UPGRADE
───────────────────────────────────────────────────────────── */
.footer {
  background: linear-gradient(180deg, #08080f 0%, #050505 100%) !important;
  border-top: 1px solid rgba(212,175,55,.12) !important;
}

.footer-column h3 {
  font-size: .78rem !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  position: relative;
  padding-bottom: .9rem !important;
  margin-bottom: 1.2rem !important;
}
.footer-column h3::after {
  content: '';
  position: absolute; bottom: 0; left: 0;
  width: 22px; height: 1px;
  background: linear-gradient(90deg, var(--c-gold), transparent);
}

.footer-column ul li a {
  color: var(--c-text-muted) !important;
  font-size: var(--fz-xs) !important;
  letter-spacing: .02em;
  padding: 2px 0;
  display: block;
}
.footer-column ul li a:hover { color: var(--c-gold) !important; }

.social-icons a {
  border-radius: var(--r-xs) !important;
  font-size: var(--fz-xs) !important;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: var(--c-surface) !important;
  border-color: var(--c-border-2) !important;
}
.social-icons a:hover {
  border-color: var(--c-gold-dim) !important;
  background: var(--c-gold-glow) !important;
}

.footer-bottom {
  border-top-color: rgba(212,175,55,.06) !important;
}

/* ─────────────────────────────────────────────────────────────
   15. NOTIFICATION — upgrade toast
───────────────────────────────────────────────────────────── */
.notification {
  border-radius: var(--r-md) !important;
  border-left-color: var(--c-gold) !important;
  background: rgba(13,13,26,.97) !important;
  border: 1px solid var(--c-border) !important;
  border-left: 3px solid var(--c-gold) !important;
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-lg) !important;
  font-size: var(--fz-sm) !important;
  padding: 14px 20px !important;
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 280px;
  max-width: 360px;
}

/* ─────────────────────────────────────────────────────────────
   16. BADGE COMPONENT
───────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fz-xs);
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: var(--r-pill);
}
.badge-gold {
  background: rgba(212,175,55,.12);
  color: var(--c-gold);
  border: 1px solid rgba(212,175,55,.25);
}
.badge-new {
  background: rgba(80,200,140,.12);
  color: #50c88c;
  border: 1px solid rgba(80,200,140,.25);
}
.badge-sale {
  background: rgba(220,80,80,.12);
  color: #e05050;
  border: 1px solid rgba(220,80,80,.25);
}

/* ─────────────────────────────────────────────────────────────
   17. FLOATING BUTTONS — upgrade
───────────────────────────────────────────────────────────── */
.floating-btn {
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid var(--c-gold-dim) !important;
  box-shadow: var(--shadow-md), 0 0 0 1px rgba(0,0,0,.4) !important;
  transition:
    box-shadow var(--tr-base),
    background var(--tr-base),
    transform var(--tr-fast) !important;
}
.floating-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-gold), var(--shadow-md) !important;
}

/* ─────────────────────────────────────────────────────────────
   18. GOLD SHIMMER UTILITY — для акцентных элементов
───────────────────────────────────────────────────────────── */
@keyframes goldShimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}
.gold-shimmer {
  background: linear-gradient(90deg,
    var(--c-gold) 0%,
    var(--c-gold-light) 40%,
    #ffe17a 50%,
    var(--c-gold-light) 60%,
    var(--c-gold) 100%
  );
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: goldShimmer 3s linear infinite;
}

/* ─────────────────────────────────────────────────────────────
   19. SCROLLBAR — single place
───────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: #08080f; }
::-webkit-scrollbar-thumb {
  background: rgba(212,175,55,.2);
  border-radius: var(--r-pill);
  border: 2px solid #08080f;
}
::-webkit-scrollbar-thumb:hover { background: rgba(212,175,55,.4); }

/* ─────────────────────────────────────────────────────────────
   20. RESPONSIVE HELPERS
───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .hide-mobile { display: none !important; }
  .ds-title { text-align: left; }
  .ds-sub { text-align: left; margin-left: 0; }
  .ds-divider { margin-left: 0; }
}
@media (min-width: 769px) {
  .hide-desktop { display: none !important; }
}

/* ─────────────────────────────────────────────────────────────
   21. FILTER/TAG PILLS — унификация
───────────────────────────────────────────────────────────── */
.tag-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--c-surface);
  border: 1px solid var(--c-border-2);
  color: var(--c-text-dim);
  border-radius: var(--r-pill);
  padding: .4rem 1rem;
  font-size: var(--fz-xs);
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all var(--tr-fast);
  white-space: nowrap;
}
.tag-pill:hover {
  border-color: var(--c-gold-dim);
  color: var(--c-gold);
  background: var(--c-gold-glow);
}
.tag-pill.active {
  background: linear-gradient(135deg, rgba(212,175,55,.2), rgba(212,175,55,.08));
  border-color: var(--c-gold-dim);
  color: var(--c-gold);
  font-weight: 600;
}


/* ═══════════════════════════════════════════════════════════════
   UX IMPROVEMENTS — animations, effects, engagement
═══════════════════════════════════════════════════════════════ */

/* ── Scroll reveal ──────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s var(--ease-smooth), transform .6s var(--ease-smooth);
}
.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }

/* ── Shimmer loading skeleton ───────────────────────────────── */
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
.skeleton {
  background: linear-gradient(90deg, #1a1a2e 25%, #2d2d4e 50%, #1a1a2e 75%);
  background-size: 800px 100%;
  animation: shimmer 1.4s infinite;
  border-radius: var(--r-sm);
}

/* ── Gold pulse glow (CTA buttons) ─────────────────────────── */
@keyframes goldPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(212,175,55,.0), var(--shadow-md); }
  50%      { box-shadow: 0 0 0 8px rgba(212,175,55,.15), var(--shadow-md); }
}
.btn-gold-pulse:hover, .cta-primary:hover {
  animation: goldPulse 2s infinite;
}

/* ── Particle stars background ─────────────────────────────── */
@keyframes starTwinkle {
  0%,100% { opacity: .2; transform: scale(1); }
  50%      { opacity: .9; transform: scale(1.4); }
}
.star-particle {
  position: absolute;
  width: 2px;
  height: 2px;
  background: #d4af37;
  border-radius: 50%;
  animation: starTwinkle var(--dur, 3s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
  pointer-events: none;
}

/* ── Card hover lift ────────────────────────────────────────── */
.card-hover {
  transition: transform var(--tr-base), box-shadow var(--tr-base);
  will-change: transform;
}
.card-hover:hover {
  transform: translateY(-5px) scale(1.01);
  box-shadow: var(--shadow-lg), 0 0 30px rgba(155,89,182,.12);
}

/* ── Product card improvements ──────────────────────────────── */
.product-card {
  transition: transform var(--tr-base), box-shadow var(--tr-base), border-color var(--tr-base) !important;
}
.product-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 20px 50px rgba(0,0,0,.6), 0 0 30px rgba(212,175,55,.1) !important;
  border-color: rgba(212,175,55,.3) !important;
}

/* ── Magical divider ────────────────────────────────────────── */
.magic-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 2.5rem 0;
  opacity: .5;
}
.magic-divider::before,
.magic-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--c-gold-dim), transparent);
}
.magic-divider-icon {
  color: var(--c-gold);
  font-size: .85rem;
  letter-spacing: .1em;
}

/* ── Notification bar (sticky CTA) ─────────────────────────── */
.sticky-notify-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(135deg, #1a0a2e, #0a0a1a);
  border-top: 1px solid rgba(155,89,182,.3);
  padding: .8rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 1000;
  transform: translateY(100%);
  transition: transform .4s var(--ease-out);
  box-shadow: 0 -10px 40px rgba(0,0,0,.4);
}
.sticky-notify-bar.visible { transform: translateY(0); }
.sticky-notify-bar-text { color: #ddd; font-size: .9rem; }
.sticky-notify-bar-text strong { color: var(--c-gold); }
.sticky-notify-bar-close {
  background: none;
  border: none;
  color: #666;
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0 .5rem;
  transition: color var(--tr-fast);
}
.sticky-notify-bar-close:hover { color: #aaa; }

/* ── Floating action buttons ────────────────────────────────── */
.fab-container {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .75rem;
  z-index: 999;
}
.fab-btn {
  display: flex;
  align-items: center;
  gap: .6rem;
  background: linear-gradient(135deg, #9b59b6, #8e44ad);
  color: #fff;
  border: none;
  padding: .75rem 1.2rem;
  border-radius: var(--r-pill);
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(155,89,182,.4);
  transition: all var(--tr-base);
  text-decoration: none;
  white-space: nowrap;
}
.fab-btn:hover {
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 8px 30px rgba(155,89,182,.6);
  color: #fff;
}
.fab-btn.fab-secondary {
  background: linear-gradient(135deg, #1a1a2e, #2d2d4e);
  border: 1px solid rgba(212,175,55,.25);
  color: var(--c-gold);
  box-shadow: 0 4px 16px rgba(0,0,0,.4);
  font-size: .8rem;
  padding: .55rem 1rem;
}
.fab-btn.fab-secondary:hover {
  border-color: rgba(212,175,55,.5);
  box-shadow: 0 8px 24px rgba(0,0,0,.5);
}

/* ── Section entrance animations ───────────────────────────── */
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
.animate-entrance {
  animation: fadeSlideUp .6s var(--ease-smooth) both;
}

/* ── Typing cursor effect ───────────────────────────────────── */
@keyframes blink { 50% { opacity: 0; } }
.typing-cursor::after {
  content: '|';
  animation: blink 1s step-end infinite;
  color: var(--c-gold);
  margin-left: 2px;
}

/* ── Reading card enhanced hover ────────────────────────────── */
.reading-card {
  transition: transform var(--tr-base), box-shadow var(--tr-base), border-color var(--tr-base) !important;
}
.reading-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 24px 60px rgba(0,0,0,.6), 0 0 40px rgba(155,89,182,.2) !important;
}

/* ── Review card hover ──────────────────────────────────────── */
.review-card {
  transition: transform var(--tr-base), box-shadow var(--tr-base) !important;
}
.review-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,.5) !important;
}

/* ── Header scroll effect (JS adds .scrolled) ───────────────── */
.header.scrolled {
  background: rgba(5,5,5,.97) !important;
  backdrop-filter: blur(20px) !important;
  box-shadow: 0 2px 30px rgba(0,0,0,.6) !important;
  border-bottom: 1px solid rgba(212,175,55,.12) !important;
}

/* ── Input focus effects ────────────────────────────────────── */
input:focus, textarea:focus, select:focus {
  box-shadow: 0 0 0 3px rgba(155,89,182,.2);
  border-color: rgba(155,89,182,.5) !important;
  outline: none;
}

/* ── Smooth scrollbar (Chrome/Edge) ────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: #0a0a14; }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #9b59b6, #d4af37);
  border-radius: 3px;
}

/* ── Text selection colour ──────────────────────────────────── */
::selection {
  background: rgba(155,89,182,.3);
  color: #fff;
}
