/* ══════════════════════════════════════════════════════════════
   MORNING OVERLAY — Sacred daily greeting

   Full-screen takeover on first app open each calendar day.
   Organic, non-geometric shapes throughout — flowing SVG paths,
   natural forms, no circles, boxes, or standard rectangular cards.
   Animations are gentle and unhurried: soft fades, subtle pulses.
   ══════════════════════════════════════════════════════════════ */

/* ── Overlay Shell ───────────────────────────────────────────── */

.morning-overlay {
  position: fixed;
  inset: 0;
  z-index: 500; /* Above everything including toasts */
  background: var(--color-bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  opacity: 1;
  filter: blur(0);
  transition: opacity 500ms cubic-bezier(0.4, 0, 0.2, 1),
              transform 500ms cubic-bezier(0.4, 0, 0.2, 1),
              filter 500ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: opacity, transform, filter;
}

.morning-overlay[hidden] {
  display: none;
}

/* Dissolve / recede — the overlay lifts gently and dissolves,
   revealing the pulse hub underneath. */
.morning-overlay--dismissing {
  opacity: 0;
  transform: translateY(-18px) scale(0.96);
  filter: blur(6px);
  pointer-events: none;
}

/* ── Background Blobs ────────────────────────────────────────── */
/* Organic flowing shapes that drift behind the content,
   creating depth and a living, sacred atmosphere. */

.morning-overlay__bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}

.morning-overlay__blob {
  position: absolute;
  opacity: 0;
  animation: morningBlobFadeIn 1.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  will-change: opacity, transform;
}

.morning-overlay__blob--top {
  top: -8%;
  right: -15%;
  width: 75%;
  animation-delay: 0.2s;
}

.morning-overlay__blob--bottom {
  bottom: -12%;
  left: -20%;
  width: 80%;
  animation-delay: 0.5s;
}

.morning-overlay__blob--accent {
  top: 35%;
  left: -10%;
  width: 40%;
  animation-delay: 0.8s;
}

.morning-overlay__blob svg {
  width: 100%;
  height: auto;
  display: block;
}

/* Gentle drifting animation for blobs */
.morning-overlay__blob--top svg {
  animation: morningBlobDrift1 12s ease-in-out infinite;
}

.morning-overlay__blob--bottom svg {
  animation: morningBlobDrift2 14s ease-in-out infinite;
}

.morning-overlay__blob--accent svg {
  animation: morningBlobDrift3 10s ease-in-out infinite;
}

@keyframes morningBlobFadeIn {
  from {
    opacity: 0;
    transform: scale(0.92);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes morningBlobDrift1 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  33% { transform: translate(3%, 2%) rotate(1deg); }
  66% { transform: translate(-2%, -1%) rotate(-0.5deg); }
}

@keyframes morningBlobDrift2 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  40% { transform: translate(-3%, -2%) rotate(-1deg); }
  70% { transform: translate(2%, 1%) rotate(0.5deg); }
}

@keyframes morningBlobDrift3 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(4%, -3%) scale(1.04); }
}

/* ── Content Container ───────────────────────────────────────── */

.morning-overlay__content {
  position: relative;
  z-index: 1;
  max-width: 380px;
  width: 100%;
  padding: var(--space-8) var(--space-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  opacity: 0;
  animation: morningContentReveal 1s cubic-bezier(0.4, 0, 0.2, 1) 0.4s forwards;
}

@keyframes morningContentReveal {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Date Label ──────────────────────────────────────────────── */

.morning-overlay__date {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  margin-bottom: var(--space-6);
}

/* ── Scripture Section ───────────────────────────────────────── */
/* Passage displayed with organic flowing separator, no card/box. */

.morning-overlay__scripture {
  width: 100%;
  margin-bottom: var(--space-8);
}

.morning-overlay__passage-text {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: var(--text-xl);
  font-weight: var(--weight-normal);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
  max-width: 28ch;
  margin: 0 auto;
  opacity: 0;
  animation: morningTextFade 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.7s forwards;
}

.morning-overlay__passage-ref {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-accent);
  margin-top: var(--space-3);
  letter-spacing: var(--tracking-wide);
  opacity: 0;
  animation: morningTextFade 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.9s forwards;
}

.morning-overlay__passage-link {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-accent);
  text-decoration: none;
  margin-top: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-bottom: 1px solid var(--color-accent-faint);
  transition: color var(--duration-fast) var(--ease-default),
              border-color var(--duration-fast) var(--ease-default);
  opacity: 0;
  animation: morningTextFade 0.8s cubic-bezier(0.4, 0, 0.2, 1) 1s forwards;
}

.morning-overlay__passage-link:hover,
.morning-overlay__passage-link:focus-visible {
  color: var(--color-text-primary);
  border-color: var(--color-accent);
}

@keyframes morningTextFade {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Organic Separator ───────────────────────────────────────── */
/* A flowing SVG line between scripture and stones — not a straight hr */

.morning-overlay__separator {
  width: 120px;
  margin: 0 auto var(--space-6);
  opacity: 0;
  animation: morningTextFade 0.8s cubic-bezier(0.4, 0, 0.2, 1) 1.1s forwards;
}

.morning-overlay__separator svg {
  width: 100%;
  height: auto;
  display: block;
}

/* ── Stones Section ──────────────────────────────────────────── */

.morning-overlay__stones {
  width: 100%;
  opacity: 0;
  animation: morningTextFade 0.8s cubic-bezier(0.4, 0, 0.2, 1) 1.2s forwards;
}

.morning-overlay__stones-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  margin-bottom: var(--space-4);
}

/* ── Stone Items ─────────────────────────────────────────────── */
/* Organic, non-rectangular stone markers */

.morning-overlay__stone {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-2);
  background: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  /* Organic shape — asymmetric border-radius */
  border-radius: 1.5rem 2rem 1.8rem 1.2rem / 2rem 1.2rem 2.2rem 1.5rem;
  transition: background var(--duration-fast) var(--ease-default);
}

.morning-overlay__stone:last-child {
  margin-bottom: 0;
}

.morning-overlay__stone-dot {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  /* Organic dot shape — slightly irregular */
  border-radius: 60% 40% 50% 45% / 45% 55% 40% 60%;
}

.morning-overlay__stone-title {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
  line-height: var(--leading-snug);
  text-align: left;
}

.morning-overlay__stone-role {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  margin-left: auto;
  flex-shrink: 0;
  white-space: nowrap;
}

/* ── Empty State ─────────────────────────────────────────────── */
/* Gentle default message when no content is available */

.morning-overlay__empty {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
  max-width: 24ch;
  margin: 0 auto;
  opacity: 0;
  animation: morningTextFade 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.7s forwards;
}

.morning-overlay__empty-hint {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
  margin-top: var(--space-3);
  line-height: var(--leading-normal);
}

/* ── Dismiss Affordance ──────────────────────────────────────── */

.morning-overlay__dismiss {
  margin-top: var(--space-10);
  opacity: 0;
  animation: morningDismissReveal 1s cubic-bezier(0.4, 0, 0.2, 1) 1.6s forwards;
}

.morning-overlay__dismiss-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: none;
  border: none;
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--color-accent);
  cursor: pointer;
  padding: var(--space-3) var(--space-6);
  /* Organic button shape */
  border-radius: 2rem 2.5rem 2rem 2.2rem / 2.2rem 2rem 2.5rem 2rem;
  transition: color var(--duration-normal) var(--ease-default),
              background var(--duration-normal) var(--ease-default);
  -webkit-tap-highlight-color: transparent;
  animation: morningDismissPulse 3s ease-in-out 2.5s infinite;
}

.morning-overlay__dismiss-btn:hover,
.morning-overlay__dismiss-btn:focus-visible {
  background: var(--color-accent-faint);
  color: var(--color-text-primary);
}

.morning-overlay__dismiss-arrow {
  display: inline-block;
  transition: transform var(--duration-normal) var(--ease-default);
}

.morning-overlay__dismiss-btn:hover .morning-overlay__dismiss-arrow {
  transform: translateY(2px);
}

@keyframes morningDismissReveal {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes morningDismissPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

/* ── Reduced Motion ──────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .morning-overlay {
    transition: opacity 200ms var(--ease-default);
    transform: none !important;
    filter: none !important;
  }

  .morning-overlay--dismissing {
    transform: none;
    filter: none;
  }

  .morning-overlay__blob,
  .morning-overlay__content,
  .morning-overlay__passage-text,
  .morning-overlay__passage-ref,
  .morning-overlay__passage-link,
  .morning-overlay__separator,
  .morning-overlay__stones,
  .morning-overlay__empty,
  .morning-overlay__dismiss {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .morning-overlay__blob--top svg,
  .morning-overlay__blob--bottom svg,
  .morning-overlay__blob--accent svg {
    animation: none !important;
  }

  .morning-overlay__dismiss-btn {
    animation: none !important;
  }
}

/* ── Mobile Adjustments ──────────────────────────────────────── */

@media (max-width: 430px) {
  .morning-overlay__content {
    padding: var(--space-6) var(--space-5);
  }

  .morning-overlay__passage-text {
    font-size: var(--text-lg);
  }
}

@media (max-width: 320px) {
  .morning-overlay__passage-text {
    font-size: var(--text-base);
  }

  .morning-overlay__content {
    padding: var(--space-4) var(--space-4);
  }
}
