/* stage-30-add-menu-polish: final Warm Glass OS entry point for quick actions. */

.add-menu-wrap {
  align-items: center;
}

.top-add-button {
  --add-button-accent: var(--accent-terracotta, #c56a4b);
  isolation: isolate;
  flex: 0 0 auto;
  min-width: 11.2rem;
  min-height: 3.35rem;
  height: 3.35rem;
  padding: 0 1.18rem;
  gap: 0.7rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--add-button-accent) 26%, rgba(255, 255, 255, 0.34)) !important;
  color: color-mix(in srgb, var(--text-primary, #2f2a26) 82%, #fff 18%) !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.38), transparent 7.5rem),
    linear-gradient(135deg, color-mix(in srgb, var(--add-button-accent) 70%, #fff 14%), color-mix(in srgb, var(--accent-amber, #d89a3d) 58%, var(--primary) 16%)) !important;
  box-shadow:
    0 1.15rem 2.7rem color-mix(in srgb, var(--add-button-accent) 22%, transparent),
    0 0 0 1px color-mix(in srgb, #fff 16%, transparent) inset,
    0 1px 0 rgba(255, 255, 255, 0.24) inset !important;
}

.top-add-button::before {
  content: "";
  position: absolute;
  inset: 1px;
  z-index: -1;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.18), transparent 62%);
  pointer-events: none;
}

.top-add-button::after {
  opacity: 0.72;
}

.top-add-button > span:first-child {
  width: 1.9rem;
  height: 1.9rem;
  background: color-mix(in srgb, #fff 26%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2);
  transition: transform 220ms cubic-bezier(.2, .8, .2, 1);
}

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

.top-add-button:hover,
.top-add-button:focus-visible,
.top-add-button[aria-expanded="true"] {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--add-button-accent) 44%, rgba(255, 255, 255, 0.42)) !important;
  box-shadow:
    0 1.35rem 3.3rem color-mix(in srgb, var(--add-button-accent) 28%, transparent),
    0 0 0 4px color-mix(in srgb, var(--add-button-accent) 13%, transparent),
    0 0 0 1px color-mix(in srgb, #fff 20%, transparent) inset,
    0 1px 0 rgba(255, 255, 255, 0.28) inset !important;
}

.add-menu {
  --add-menu-radius: 1.65rem;
  isolation: isolate;
  overflow: hidden;
  transform-origin: top right;
  border-radius: var(--add-menu-radius) !important;
  border-color: color-mix(in srgb, var(--surface-border-strong, var(--glass-border)) 74%, transparent) !important;
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 13rem),
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--accent-amber, #d89a3d) 14%, transparent), transparent 12rem),
    linear-gradient(145deg, color-mix(in srgb, var(--surface-elevated, var(--glass-elevated)) 88%, transparent), color-mix(in srgb, var(--surface-glass, var(--glass-surface)) 78%, transparent)) !important;
  box-shadow:
    0 1.8rem 4.8rem color-mix(in srgb, var(--text-primary, #2f2a26) 18%, transparent),
    0 0 0 1px color-mix(in srgb, #fff 12%, transparent) inset,
    0 1px 0 rgba(255, 255, 255, 0.18) inset !important;
  backdrop-filter: blur(30px) saturate(1.06);
  -webkit-backdrop-filter: blur(30px) saturate(1.06);
}

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

.add-menu-head {
  padding: 0.78rem 0.85rem 0.62rem;
}

.add-menu-head strong {
  font-size: 1.08rem;
  letter-spacing: 0;
}

.add-menu-head small {
  color: var(--text-muted, var(--text-secondary));
}

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

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

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

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

.add-menu button {
  position: relative;
  overflow: hidden;
  grid-template-columns: 2.72rem minmax(0, 1fr);
  min-height: 4.25rem !important;
  border-color: color-mix(in srgb, var(--add-action, var(--primary)) 14%, var(--surface-border, var(--glass-border))) !important;
  border-radius: 1.08rem !important;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--add-action, var(--primary)) 7%, var(--surface-elevated, var(--glass-elevated))), color-mix(in srgb, var(--surface-glass, var(--glass-surface)) 84%, transparent)) !important;
}

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

.add-menu button:hover,
.add-menu button:focus-visible {
  transform: translateX(2px) translateY(-1px);
  border-color: color-mix(in srgb, var(--add-action, var(--primary)) 36%, var(--surface-border-strong, var(--glass-border))) !important;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--add-action, var(--primary)) 13%, 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-action, var(--primary)) 12%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.17);
}

.add-menu-icon {
  width: 2.45rem;
  height: 2.45rem;
  border-radius: 1rem;
  color: color-mix(in srgb, var(--add-action, var(--primary)) 72%, var(--text-primary));
  background:
    radial-gradient(circle at 28% 18%, color-mix(in srgb, #fff 32%, transparent), transparent 2.1rem),
    linear-gradient(145deg, color-mix(in srgb, var(--add-action, var(--primary)) 16%, transparent), color-mix(in srgb, var(--surface-elevated, #fff) 64%, transparent));
}

.add-menu-copy strong {
  font-size: 0.96rem;
  font-weight: 760;
}

.add-menu-copy small {
  color: var(--text-muted, var(--text-secondary));
  font-size: 0.79rem;
}

@media (max-width: 760px) {
  .add-menu-backdrop:not([hidden]) {
    background:
      radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--primary) 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 {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: min(100%, 34rem) !important;
    max-height: min(78dvh, 34rem);
    margin: 0 auto;
    padding: 0.75rem 1rem calc(1rem + env(safe-area-inset-bottom)) !important;
    border-radius: 2rem 2rem 0 0 !important;
    animation: focusAddMenuSheetIn 220ms cubic-bezier(.2, .8, .2, 1);
  }

  .add-menu::before {
    display: block;
    width: 2.9rem;
    height: 0.28rem;
    margin: 0.1rem auto 0.4rem;
  }

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

  .add-menu-head small {
    font-size: 0.78rem;
  }

  .add-menu button {
    min-height: 4.55rem !important;
    border-radius: 1.2rem !important;
  }

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

  .top-add-button {
    min-height: 3rem;
    min-width: 10rem;
  }
}

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

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

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

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

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