/* stage-48-add-flow-polish: primary Add button and quick action menu. */

.top-add-button {
  --add-flow-action: var(--focus-accent-terracotta, #c56a4b);
  position: relative;
  isolation: isolate;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.72rem;
  min-width: 11.35rem !important;
  min-height: 54px !important;
  height: 54px !important;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--add-flow-action) 30%, rgba(255,255,255,.38)) !important;
  border-radius: 999px !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.42), transparent 7.8rem),
    linear-gradient(135deg, color-mix(in srgb, var(--add-flow-action) 72%, #fff 16%), color-mix(in srgb, var(--focus-accent-amber, #d89a3d) 56%, var(--primary, #5678f5) 14%)) !important;
  box-shadow:
    0 18px 44px color-mix(in srgb, var(--add-flow-action) 22%, transparent),
    0 0 0 1px color-mix(in srgb, #fff 18%, transparent) inset,
    inset 0 1px 0 rgba(255,255,255,.28) !important;
  color: color-mix(in srgb, var(--text-primary, #2f2a26) 82%, #fff 18%) !important;
  backdrop-filter: blur(24px) saturate(1.04);
  -webkit-backdrop-filter: blur(24px) saturate(1.04);
  padding: 0 1.16rem !important;
}

.top-add-button::before {
  position: absolute;
  inset: 1px;
  z-index: -1;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,.22), transparent 62%),
    radial-gradient(circle at 90% 18%, color-mix(in srgb, var(--primary, #5678f5) 13%, transparent), transparent 7rem);
  content: "";
  pointer-events: none;
}

.top-add-button > span:first-child {
  display: inline-grid !important;
  width: 31px !important;
  min-width: 31px !important;
  height: 31px !important;
  min-height: 31px !important;
  place-items: center;
  border: 1px solid color-mix(in srgb, #fff 22%, transparent);
  border-radius: 999px;
  background:
    radial-gradient(circle at 32% 12%, rgba(255,255,255,.34), transparent 54%),
    color-mix(in srgb, #fff 24%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22);
  color: inherit;
  font-size: 1.26rem;
  font-weight: 690;
  line-height: 1;
  transition: transform var(--focus-motion-standard, 220ms cubic-bezier(.2,.8,.2,1));
}

.top-add-button > span:last-child {
  color: inherit;
  font-size: 0.98rem;
  font-weight: 780;
  line-height: 1;
}

.top-add-button:is(:hover, :focus-visible),
.top-add-button[aria-expanded="true"] {
  border-color: color-mix(in srgb, var(--add-flow-action) 48%, rgba(255,255,255,.46)) !important;
  box-shadow:
    0 22px 58px color-mix(in srgb, var(--add-flow-action) 28%, transparent),
    0 0 0 4px color-mix(in srgb, var(--add-flow-action) 14%, transparent),
    0 0 0 1px color-mix(in srgb, #fff 20%, transparent) inset,
    inset 0 1px 0 rgba(255,255,255,.32) !important;
  outline: none;
  transform: translateY(-1px);
}

.top-add-button[aria-expanded="true"] > span:first-child {
  transform: rotate(45deg);
}

.add-menu {
  --add-menu-radius: 28px;
  position: absolute;
  right: 0;
  display: grid;
  gap: 0.56rem !important;
  width: min(23.2rem, calc(100vw - 2rem)) !important;
  overflow: hidden !important;
  border: 1px solid color-mix(in srgb, var(--surface-border-strong, var(--glass-border-strong)) 76%, transparent) !important;
  border-radius: var(--add-menu-radius) !important;
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--primary, #5678f5) 14%, transparent), transparent 14rem),
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--focus-accent-amber, #d89a3d) 14%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--surface-elevated, var(--glass-elevated)) 90%, transparent), color-mix(in srgb, var(--surface-glass, var(--glass-surface)) 80%, transparent)) !important;
  box-shadow:
    0 30px 76px color-mix(in srgb, var(--text-primary, #2f2a26) 18%, transparent),
    0 0 0 1px color-mix(in srgb, #fff 13%, transparent) inset,
    inset 0 1px 0 rgba(255,255,255,.2) !important;
  backdrop-filter: blur(30px) saturate(1.08);
  -webkit-backdrop-filter: blur(30px) saturate(1.08);
  padding: 0.78rem !important;
  transform-origin: top right;
}

.add-menu::after {
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: inherit;
  background:
    linear-gradient(120deg, rgba(255,255,255,.15), transparent 38%),
    radial-gradient(circle at 50% 100%, color-mix(in srgb, var(--primary, #5678f5) 8%, transparent), transparent 14rem);
  content: "";
  opacity: 0.82;
  pointer-events: none;
}

.add-menu-head {
  display: grid;
  gap: 0.16rem;
  padding: 0.54rem 0.62rem 0.48rem !important;
}

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

.add-menu-head small {
  color: var(--text-muted, var(--text-secondary, #6f655e));
  font-size: 0.78rem;
  font-weight: 580;
}

.add-menu button {
  --add-flow-action: var(--primary, #5678f5);
  --add-flow-icon: var(--icon-plus);
  position: relative;
  display: grid !important;
  grid-template-columns: 44px minmax(0, 1fr);
  align-items: center;
  gap: 0.78rem !important;
  min-height: 66px !important;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--add-flow-action) 15%, var(--surface-border, var(--glass-border))) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--add-flow-action) 8%, var(--surface-elevated, var(--glass-elevated))), color-mix(in srgb, var(--surface-glass, var(--glass-surface)) 84%, transparent)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
  color: var(--text-primary, #2f2a26);
  cursor: pointer;
  padding: 0.7rem 0.82rem !important;
  text-align: left;
}

.add-menu button::before {
  position: absolute;
  left: 0.52rem;
  top: 0.72rem;
  bottom: 0.72rem;
  width: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--add-flow-action) 78%, #fff 6%);
  box-shadow: 0 0 1rem color-mix(in srgb, var(--add-flow-action) 28%, transparent);
  content: "";
  opacity: 0.7;
}

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

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

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

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

.add-menu button:is(:hover, :focus-visible) {
  border-color: color-mix(in srgb, var(--add-flow-action) 38%, var(--surface-border-strong, var(--glass-border-strong))) !important;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--add-flow-action) 14%, var(--surface-elevated, var(--glass-elevated))), color-mix(in srgb, var(--surface-glass, var(--glass-surface)) 88%, transparent)) !important;
  box-shadow:
    0 0.9rem 2.1rem color-mix(in srgb, var(--add-flow-action) 13%, transparent),
    inset 0 1px 0 rgba(255,255,255,.19);
  outline: none;
  transform: translateX(2px) translateY(-1px);
}

.add-menu-icon {
  position: relative;
  display: inline-grid !important;
  width: 42px !important;
  min-width: 42px !important;
  height: 42px !important;
  min-height: 42px !important;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--add-flow-action) 16%, var(--surface-border, var(--glass-border))) !important;
  border-radius: 16px !important;
  background:
    radial-gradient(circle at 30% 16%, rgba(255,255,255,.34), transparent 2.15rem),
    linear-gradient(145deg, color-mix(in srgb, var(--add-flow-action) 17%, transparent), color-mix(in srgb, var(--surface-elevated, #fff) 62%, transparent)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.2);
  color: color-mix(in srgb, var(--add-flow-action) 78%, var(--text-primary, #2f2a26));
}

.add-menu-icon::before {
  content: "" !important;
  position: static !important;
  display: block !important;
  width: 22px !important;
  height: 22px !important;
  inset: auto !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: currentColor !important;
  -webkit-mask: var(--add-flow-icon) center / contain no-repeat !important;
  mask: var(--add-flow-icon) center / contain no-repeat !important;
  transform: none !important;
}

.add-menu-icon::after {
  display: none !important;
}

.add-menu-copy {
  display: grid;
  min-width: 0;
  gap: 0.22rem;
}

.add-menu-copy strong {
  overflow: hidden;
  color: var(--text-primary, #2f2a26);
  font-size: 0.96rem;
  font-weight: 770;
  line-height: 1.14;
  text-overflow: ellipsis;
}

.add-menu-copy small {
  color: var(--text-muted, var(--text-secondary, #6f655e));
  font-size: 0.78rem;
  font-weight: 580;
  line-height: 1.26;
}

@media (max-width: 760px) {
  body.add-menu-open {
    overflow: hidden;
  }

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

  body.add-menu-open .add-menu {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    bottom: 0 !important;
    z-index: 90 !important;
    width: min(100%, 34rem) !important;
    max-height: min(78dvh, 34rem);
    margin: 0 auto;
    overflow: auto !important;
    border-radius: 32px 32px 0 0 !important;
    padding: 0.82rem 1rem calc(1rem + env(safe-area-inset-bottom)) !important;
    transform-origin: bottom center;
    animation: focusAddFlowSheetIn 220ms cubic-bezier(.2, .8, .2, 1);
  }

  .add-menu::before {
    display: block;
    justify-self: center;
    width: 46px;
    height: 4px;
    margin: 0.1rem 0 0.36rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--text-secondary, #6f655e) 28%, transparent);
    content: "";
  }

  .add-menu-head {
    justify-items: center;
    padding: 0.36rem 0.75rem 0.74rem !important;
    text-align: center;
  }

  .add-menu button {
    min-height: 72px !important;
    border-radius: 20px !important;
    transform: none;
  }

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

  .top-add-button {
    width: 100%;
    min-width: 0 !important;
    height: 52px !important;
    min-height: 52px !important;
  }
}

@media (max-width: 430px) {
  .add-menu button {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 0.68rem !important;
    padding-inline: 0.76rem !important;
  }

  .add-menu-copy small {
    font-size: 0.74rem;
  }
}

@keyframes focusAddFlowSheetIn {
  from {
    opacity: 0;
    transform: translateY(1.2rem) scale(0.985);
  }

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

@media (prefers-reduced-motion: reduce) {
  .top-add-button,
  .top-add-button > span:first-child,
  .add-menu,
  .add-menu button {
    animation: none !important;
    transition: none !important;
  }

  .top-add-button:is(:hover, :focus-visible),
  .top-add-button[aria-expanded="true"],
  .add-menu button:is(:hover, :focus-visible) {
    transform: none !important;
  }
}
