/* stage-69-add-menu-panel-polish: Warm Glass OS quick action menu and mobile sheet. */

.app-shell {
  --focus-add-menu-width: min(24rem, calc(100vw - 2rem));
  --focus-add-menu-radius: 26px;
  --focus-add-menu-sheet-radius: 30px 30px 0 0;
  --focus-add-menu-item-min: 66px;
  --focus-add-menu-icon-size: 44px;
  --focus-add-menu-gap: 9px;
}

.add-menu-wrap {
  isolation: isolate;
}

.add-menu:not([hidden]) {
  position: absolute;
  top: calc(100% + 14px) !important;
  right: 0 !important;
  z-index: 90;
  display: grid;
  width: var(--focus-add-menu-width);
  max-height: min(72vh, 430px);
  gap: var(--focus-add-menu-gap);
  padding: 12px;
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--surface-border-strong, var(--glass-border)) 72%, transparent) !important;
  border-radius: var(--focus-add-menu-radius) !important;
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--primary, #5678f5) 13%, transparent), transparent 14rem),
    radial-gradient(circle at 100% 8%, color-mix(in srgb, var(--focus-accent-amber, #d89a3d) 16%, transparent), transparent 13rem),
    linear-gradient(145deg,
      color-mix(in srgb, var(--surface-elevated, rgba(255, 255, 255, 0.55)) 92%, transparent),
      color-mix(in srgb, var(--surface-glass, rgba(255, 255, 255, 0.42)) 82%, transparent)) !important;
  box-shadow:
    0 30px 78px color-mix(in srgb, var(--text-primary, #2f2a26) 17%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 24%, transparent),
    inset 0 0 0 1px color-mix(in srgb, #fff 10%, transparent) !important;
  backdrop-filter: blur(30px) saturate(1.08);
  -webkit-backdrop-filter: blur(30px) saturate(1.08);
  transform-origin: top right;
}

.add-menu:not([hidden])::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(120deg, color-mix(in srgb, #fff 16%, transparent), transparent 38%),
    radial-gradient(circle at 52% 100%, color-mix(in srgb, var(--primary, #5678f5) 8%, transparent), transparent 13rem);
  opacity: 0.86;
}

.add-menu-head {
  display: grid;
  gap: 3px;
  padding: 8px 10px 7px;
}

.add-menu-head strong {
  color: var(--text-primary, #2f2a26);
  font-size: 1.02rem;
  font-weight: 760;
  letter-spacing: 0;
}

.add-menu-head small {
  color: var(--text-muted, #9c9187);
  font-size: 0.78rem;
  font-weight: 560;
}

.add-menu button[data-action="reminder"] {
  --focus-add-action: var(--label-reminder, #5678f5);
}

.add-menu button[data-action="plan"] {
  --focus-add-action: var(--focus-accent-sage, var(--accent-sage, #5f9073));
}

.add-menu button[data-action="notes"] {
  --focus-add-action: var(--label-creative, #8c7ae6);
}

.add-menu button[data-action="schedule"] {
  --focus-add-action: var(--focus-accent-amber, var(--accent-amber, #d89a3d));
}

.add-menu button {
  position: relative;
  display: grid !important;
  min-width: 0;
  min-height: var(--focus-add-menu-item-min) !important;
  grid-template-columns: var(--focus-add-menu-icon-size) minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  padding: 10px 12px 10px 10px !important;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 15%, var(--surface-border, var(--glass-border))) !important;
  border-radius: 18px !important;
  color: var(--text-primary, #2f2a26) !important;
  background:
    linear-gradient(145deg,
      color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 8%, var(--surface-elevated, rgba(255, 255, 255, 0.55))),
      color-mix(in srgb, var(--surface-glass, rgba(255, 255, 255, 0.42)) 84%, transparent)) !important;
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 16%, transparent),
    0 10px 24px color-mix(in srgb, var(--text-primary, #2f2a26) 5%, transparent);
  transition:
    transform 220ms cubic-bezier(.2, .8, .2, 1),
    border-color 220ms cubic-bezier(.2, .8, .2, 1),
    background 220ms cubic-bezier(.2, .8, .2, 1),
    box-shadow 220ms cubic-bezier(.2, .8, .2, 1);
}

.add-menu button::before {
  content: "";
  position: absolute;
  inset: 10px auto 10px 0;
  width: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 72%, #fff 8%);
  box-shadow: 0 0 14px color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 24%, transparent);
  opacity: 0.56;
}

.add-menu button:is(:hover, :focus-visible) {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 34%, var(--surface-border-strong, var(--glass-border))) !important;
  background:
    linear-gradient(145deg,
      color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 14%, var(--surface-elevated, rgba(255, 255, 255, 0.55))),
      color-mix(in srgb, var(--surface-glass, rgba(255, 255, 255, 0.42)) 90%, transparent)) !important;
  box-shadow:
    0 14px 28px color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 13%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent);
}

.add-menu-icon {
  display: grid !important;
  width: var(--focus-add-menu-icon-size) !important;
  min-width: var(--focus-add-menu-icon-size) !important;
  height: var(--focus-add-menu-icon-size) !important;
  min-height: var(--focus-add-menu-icon-size) !important;
  place-items: center;
  overflow: visible !important;
  border-radius: 16px !important;
  color: color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 76%, var(--text-primary, #2f2a26)) !important;
  background:
    radial-gradient(circle at 28% 18%, color-mix(in srgb, #fff 34%, transparent), transparent 2.2rem),
    linear-gradient(145deg,
      color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 17%, transparent),
      color-mix(in srgb, var(--surface-elevated, #fff) 62%, transparent)) !important;
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 22%, transparent),
    0 10px 24px color-mix(in srgb, var(--focus-add-action, var(--primary, #5678f5)) 9%, transparent);
}

.add-menu-copy {
  display: grid;
  min-width: 0;
  gap: 3px;
}

.add-menu-copy strong,
.add-menu-copy small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.add-menu-copy strong {
  color: var(--text-primary, #2f2a26);
  font-size: 0.96rem;
  font-weight: 760;
  line-height: 1.18;
  white-space: nowrap;
}

.add-menu-copy small {
  color: var(--text-muted, #9c9187);
  font-size: 0.78rem;
  font-weight: 520;
  line-height: 1.25;
}

.add-menu-backdrop:not([hidden]) {
  position: fixed;
  inset: 0;
  z-index: 80;
  background: color-mix(in srgb, #11131a 18%, transparent);
}

:root[data-theme="dark"] .add-menu:not([hidden]) {
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--primary, #6f8cff) 18%, transparent), transparent 14rem),
    radial-gradient(circle at 100% 10%, color-mix(in srgb, var(--focus-accent-terracotta, #c56a4b) 14%, transparent), transparent 13rem),
    linear-gradient(145deg,
      color-mix(in srgb, var(--surface-elevated, rgba(255, 255, 255, 0.1)) 88%, #151821 12%),
      color-mix(in srgb, var(--surface-glass, rgba(255, 255, 255, 0.06)) 84%, #0f121a 16%)) !important;
}

@media (max-width: 760px) {
  .app-shell {
    --focus-add-menu-width: min(100%, 34rem);
    --focus-add-menu-item-min: 68px;
    --focus-add-menu-icon-size: 42px;
  }

  .add-menu-backdrop:not([hidden]) {
    display: block;
    z-index: 115;
    background:
      radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--primary, #5678f5) 11%, transparent), transparent 18rem),
      color-mix(in srgb, #0f1117 45%, transparent);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }

  body.add-menu-open .add-menu:not([hidden]) {
    position: fixed;
    inset: auto 0 0 0 !important;
    top: auto !important;
    bottom: 0 !important;
    z-index: 120 !important;
    width: var(--focus-add-menu-width);
    max-height: min(78dvh, 34rem);
    margin: 0 auto;
    padding: 10px 14px calc(14px + env(safe-area-inset-bottom)) !important;
    border-radius: var(--focus-add-menu-sheet-radius) !important;
    transform-origin: bottom center;
    animation: focusStage69AddSheetIn 220ms cubic-bezier(.2, .8, .2, 1);
  }

  body.add-menu-open .add-menu:not([hidden])::before {
    content: "";
    display: block;
    width: 44px;
    height: 4px;
    margin: 2px auto 7px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--text-muted, #9c9187) 42%, transparent);
  }

  .add-menu-head {
    justify-items: center;
    padding: 4px 8px 8px;
    text-align: center;
  }

  .add-menu button {
    min-height: var(--focus-add-menu-item-min) !important;
    padding: 10px 12px !important;
    border-radius: 20px !important;
  }

  .add-menu button:is(:hover, :focus-visible) {
    transform: translateY(-1px);
  }

  .add-menu-copy small {
    white-space: normal;
  }
}

@media (max-width: 420px) {
  .add-menu-copy strong {
    white-space: normal;
  }
}

@media (prefers-reduced-motion: reduce) {
  .add-menu:not([hidden]),
  .add-menu button,
  .add-menu-icon,
  .add-menu-backdrop:not([hidden]) {
    animation: none !important;
    transition: none !important;
  }

  .add-menu button:is(:hover, :focus-visible) {
    transform: none;
  }
}

@keyframes focusStage69AddSheetIn {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.985);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
