/**
 * ry-ui Component Styles
 *
 * Styles for interactive and display components.
 */

/* ═══════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════ */

.ry-btn,
ry-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ry-space-2);

  padding: var(--ry-space-2) var(--ry-space-4);

  font-family: var(--ry-font-sans);
  font-size: var(--ry-text-sm);
  font-weight: var(--ry-font-medium);
  line-height: var(--ry-leading-normal);
  text-decoration: none;
  white-space: nowrap;

  background-color: var(--ry-color-primary);
  color: var(--ry-color-text-inverse);
  border: var(--ry-border-width) solid transparent;
  border-radius: var(--ry-radius-md);

  cursor: pointer;
  user-select: none;

  transition-property: background-color, border-color, color, box-shadow;
  transition-duration: var(--ry-duration-fast);
  transition-timing-function: var(--ry-ease);
}

.ry-btn:hover,
ry-button:hover {
  background-color: var(--ry-color-primary-hover);
}

.ry-btn:active,
ry-button:active {
  background-color: var(--ry-color-primary-active);
}

.ry-btn:disabled,
.ry-btn[aria-disabled="true"],
ry-button[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Button variants */
.ry-btn--secondary,
ry-button[variant="secondary"] {
  background-color: var(--ry-color-secondary);
}
.ry-btn--secondary:hover,
ry-button[variant="secondary"]:hover {
  background-color: var(--ry-color-secondary-hover);
}

.ry-btn--outline,
ry-button[variant="outline"] {
  background-color: transparent;
  color: var(--ry-color-primary);
  border-color: var(--ry-color-primary);
}
.ry-btn--outline:hover,
ry-button[variant="outline"]:hover {
  background-color: var(--ry-color-primary);
  color: var(--ry-color-text-inverse);
}

.ry-btn--ghost,
ry-button[variant="ghost"] {
  background-color: transparent;
  color: var(--ry-color-text);
}
.ry-btn--ghost:hover,
ry-button[variant="ghost"]:hover {
  background-color: var(--ry-color-bg-muted);
}

.ry-btn--danger,
ry-button[variant="danger"] {
  background-color: var(--ry-color-danger);
}
.ry-btn--danger:hover,
ry-button[variant="danger"]:hover {
  background-color: #dc2626;
}

/* Button sizes */
.ry-btn--sm,
ry-button[size="sm"] {
  padding: var(--ry-space-1) var(--ry-space-3);
  font-size: var(--ry-text-xs);
}

.ry-btn--lg,
ry-button[size="lg"] {
  padding: var(--ry-space-3) var(--ry-space-6);
  font-size: var(--ry-text-base);
}

/* ═══════════════════════════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════════════════════════ */

ry-card {
  display: block;
  padding: var(--ry-space-6);
  background-color: var(--ry-color-bg);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-lg);
  box-shadow: var(--ry-shadow-sm);
}

ry-card h3 {
  margin: 0 0 var(--ry-space-2) 0;
  font-size: var(--ry-text-lg);
  font-weight: var(--ry-font-semibold);
}

ry-card p {
  margin: 0 0 var(--ry-space-4) 0;
  color: var(--ry-color-text-muted);
}

ry-card p:last-child {
  margin-bottom: 0;
}

/* ═══════════════════════════════════════════════════════════════
   BADGES
   ═══════════════════════════════════════════════════════════════ */

.ry-badge,
ry-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--ry-space-1) var(--ry-space-2);

  font-size: var(--ry-text-xs);
  font-weight: var(--ry-font-medium);
  line-height: 1;

  background-color: var(--ry-color-bg-muted);
  color: var(--ry-color-text);
  border-radius: var(--ry-radius-full);
}

.ry-badge--primary,
ry-badge[variant="primary"] {
  background-color: var(--ry-color-primary);
  color: var(--ry-color-text-inverse);
}

.ry-badge--success,
ry-badge[variant="success"] {
  background-color: var(--ry-color-success);
  color: var(--ry-color-text-inverse);
}

.ry-badge--warning,
ry-badge[variant="warning"] {
  background-color: var(--ry-color-warning);
  color: var(--ry-color-text);
}

.ry-badge--danger,
ry-badge[variant="danger"] {
  background-color: var(--ry-color-danger);
  color: var(--ry-color-text-inverse);
}

/* ═══════════════════════════════════════════════════════════════
   ALERTS
   ═══════════════════════════════════════════════════════════════ */

.ry-alert,
ry-alert {
  display: flex;
  gap: var(--ry-space-3);
  padding: var(--ry-space-4);

  background-color: var(--ry-color-bg-subtle);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-lg);
}

.ry-alert--info,
ry-alert[type="info"] {
  background-color: #ecfeff;
  border-color: #06b6d4;
  color: #0e7490;
}

.ry-alert--success,
ry-alert[type="success"] {
  background-color: #f0fdf4;
  border-color: #22c55e;
  color: #15803d;
}

.ry-alert--warning,
ry-alert[type="warning"] {
  background-color: #fffbeb;
  border-color: #f59e0b;
  color: #b45309;
}

.ry-alert--danger,
ry-alert[type="danger"] {
  background-color: #fef2f2;
  border-color: #ef4444;
  color: #b91c1c;
}

.ry-alert__title,
ry-alert [slot="title"] {
  margin: 0 0 var(--ry-space-1) 0;
  font-weight: var(--ry-font-semibold);
}

.ry-alert__content,
ry-alert p {
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════════
   FORM ELEMENTS
   ═══════════════════════════════════════════════════════════════ */

.ry-input,
ry-field input,
ry-field textarea,
ry-field select {
  display: block;
  width: 100%;
  padding: var(--ry-space-2) var(--ry-space-3);

  font-family: var(--ry-font-sans);
  font-size: var(--ry-text-base);
  line-height: var(--ry-leading-normal);
  color: var(--ry-color-text);

  background-color: var(--ry-color-bg);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-md);

  transition: border-color var(--ry-duration-fast) var(--ry-ease),
              box-shadow var(--ry-duration-fast) var(--ry-ease);
}

.ry-input:hover,
ry-field input:hover,
ry-field textarea:hover {
  border-color: var(--ry-color-border-strong);
}

.ry-input:focus,
ry-field input:focus,
ry-field textarea:focus {
  outline: none;
  border-color: var(--ry-color-primary);
  box-shadow: var(--ry-focus-ring);
}

.ry-input::placeholder,
ry-field input::placeholder,
ry-field textarea::placeholder {
  color: var(--ry-color-text-muted);
}

.ry-input:disabled,
ry-field input:disabled,
ry-field textarea:disabled {
  background-color: var(--ry-color-bg-muted);
  cursor: not-allowed;
  opacity: 0.5;
}

.ry-label,
ry-field label {
  display: block;
  margin-bottom: var(--ry-space-2);
  font-size: var(--ry-text-sm);
  font-weight: var(--ry-font-medium);
  color: var(--ry-color-text);
}

.ry-form-group,
ry-field {
  display: block;
  margin-bottom: var(--ry-space-4);
}

/* ═══════════════════════════════════════════════════════════════
   ACCORDION
   ═══════════════════════════════════════════════════════════════ */

ry-accordion {
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-lg);
  overflow: hidden;
}

.ry-accordion__item,
ry-accordion-item {
  border-bottom: var(--ry-border-width) solid var(--ry-color-border);
}

.ry-accordion__item:last-child,
ry-accordion-item:last-child {
  border-bottom: none;
}

.ry-accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--ry-space-4) var(--ry-space-6);

  font-family: var(--ry-font-sans);
  font-size: var(--ry-text-base);
  font-weight: var(--ry-font-medium);
  text-align: left;
  color: var(--ry-color-text);

  background-color: transparent;
  border: none;
  cursor: pointer;

  transition: background-color var(--ry-duration-fast) var(--ry-ease);
}

.ry-accordion__trigger:hover {
  background-color: var(--ry-color-bg-subtle);
}

.ry-accordion__trigger:focus-visible {
  outline: none;
  box-shadow: inset var(--ry-focus-ring);
}

.ry-accordion__icon {
  flex-shrink: 0;
  transition: transform var(--ry-duration-normal) var(--ry-ease);
}

.ry-accordion__item[data-ry-state="open"] .ry-accordion__icon {
  transform: rotate(180deg);
}

.ry-accordion__panel {
  overflow: hidden;
}

.ry-accordion__item[data-ry-state="closed"] .ry-accordion__panel {
  display: none;
}

.ry-accordion__content {
  padding: var(--ry-space-4) var(--ry-space-6);
  color: var(--ry-color-text-muted);
}

/* ═══════════════════════════════════════════════════════════════
   TABS
   ═══════════════════════════════════════════════════════════════ */

ry-tabs {
  display: block;
}

.ry-tabs__list {
  display: flex;
  gap: var(--ry-space-1);
  border-bottom: var(--ry-border-width) solid var(--ry-color-border);
  margin-bottom: var(--ry-space-4);
}

.ry-tabs__trigger {
  padding: var(--ry-space-2) var(--ry-space-4);

  font-family: var(--ry-font-sans);
  font-size: var(--ry-text-sm);
  font-weight: var(--ry-font-medium);
  color: var(--ry-color-text-muted);

  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;

  transition: color var(--ry-duration-fast) var(--ry-ease),
              border-color var(--ry-duration-fast) var(--ry-ease);
}

.ry-tabs__trigger:hover {
  color: var(--ry-color-text);
}

.ry-tabs__trigger[aria-selected="true"] {
  color: var(--ry-color-primary);
  border-bottom-color: var(--ry-color-primary);
}

.ry-tabs__trigger:focus-visible {
  outline: none;
  box-shadow: var(--ry-focus-ring);
  border-radius: var(--ry-radius-sm);
}

.ry-tabs__panel,
ry-tab {
  display: none;
}

.ry-tabs__panel[data-ry-state="active"],
ry-tab[active],
ry-tab[data-ry-state="active"] {
  display: block;
}

/* Before JS loads, show first panel */
ry-tabs:not(:defined) .ry-tabs__panel:first-of-type,
ry-tabs:not(:defined) ry-tab:first-of-type {
  display: block;
}

/* ═══════════════════════════════════════════════════════════════
   MODAL
   ═══════════════════════════════════════════════════════════════ */

ry-modal {
  display: contents;
}

.ry-modal__backdrop {
  position: fixed;
  inset: 0;
  z-index: var(--ry-z-modal-backdrop);
  background-color: var(--ry-color-overlay);

  opacity: 0;
  visibility: hidden;
  transition: opacity var(--ry-duration-normal) var(--ry-ease),
              visibility var(--ry-duration-normal) var(--ry-ease);
}

ry-modal[data-ry-state="open"] .ry-modal__backdrop {
  opacity: 1;
  visibility: visible;
}

.ry-modal__dialog {
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: var(--ry-z-modal);

  width: 100%;
  max-width: 32rem;
  max-height: calc(100vh - var(--ry-space-8));

  background-color: var(--ry-color-bg);
  border-radius: var(--ry-radius-xl);
  box-shadow: var(--ry-shadow-xl);

  overflow: auto;

  opacity: 0;
  visibility: hidden;
  transform: translate(-50%, -50%) scale(0.95);
  transition: opacity var(--ry-duration-normal) var(--ry-ease),
              visibility var(--ry-duration-normal) var(--ry-ease),
              transform var(--ry-duration-normal) var(--ry-ease);
}

ry-modal[data-ry-state="open"] .ry-modal__dialog {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, -50%) scale(1);
}

.ry-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--ry-space-4) var(--ry-space-6);
  border-bottom: var(--ry-border-width) solid var(--ry-color-border);
}

.ry-modal__title {
  margin: 0;
  font-size: var(--ry-text-lg);
  font-weight: var(--ry-font-semibold);
}

.ry-modal__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;

  font-size: var(--ry-text-xl);
  background: transparent;
  border: none;
  border-radius: var(--ry-radius-md);
  color: var(--ry-color-text-muted);
  cursor: pointer;

  transition: background-color var(--ry-duration-fast) var(--ry-ease),
              color var(--ry-duration-fast) var(--ry-ease);
}

.ry-modal__close:hover {
  background-color: var(--ry-color-bg-muted);
  color: var(--ry-color-text);
}

.ry-modal__body {
  padding: var(--ry-space-6);
}

.ry-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--ry-space-3);
  padding: var(--ry-space-4) var(--ry-space-6);
  border-top: var(--ry-border-width) solid var(--ry-color-border);
  background-color: var(--ry-color-bg-subtle);
}

/* ═══════════════════════════════════════════════════════════════
   DROPDOWN
   ═══════════════════════════════════════════════════════════════ */

ry-dropdown {
  position: relative;
  display: inline-block;
}

.ry-dropdown__menu,
ry-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: var(--ry-z-dropdown);

  min-width: 12rem;
  margin-top: var(--ry-space-1);
  padding: var(--ry-space-1);

  background-color: var(--ry-color-bg);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-lg);
  box-shadow: var(--ry-shadow-lg);

  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.5rem);
  transition: opacity var(--ry-duration-fast) var(--ry-ease),
              visibility var(--ry-duration-fast) var(--ry-ease),
              transform var(--ry-duration-fast) var(--ry-ease);
}

ry-dropdown[data-ry-state="open"] .ry-dropdown__menu,
ry-dropdown[data-ry-state="open"] ry-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.ry-dropdown__item,
ry-menu-item {
  display: block;
  width: 100%;
  padding: var(--ry-space-2) var(--ry-space-3);

  font-family: var(--ry-font-sans);
  font-size: var(--ry-text-sm);
  text-align: left;
  text-decoration: none;
  color: var(--ry-color-text);

  background: transparent;
  border: none;
  border-radius: var(--ry-radius-md);
  cursor: pointer;

  transition: background-color var(--ry-duration-fast) var(--ry-ease);
}

.ry-dropdown__item:hover,
ry-menu-item:hover {
  background-color: var(--ry-color-bg-muted);
}

.ry-dropdown__item:focus-visible,
ry-menu-item:focus-visible {
  outline: none;
  box-shadow: inset var(--ry-focus-ring);
}

.ry-dropdown__divider {
  height: 1px;
  margin: var(--ry-space-1) 0;
  background-color: var(--ry-color-border);
}

/* ═══════════════════════════════════════════════════════════════
   KEYFRAMES
   ═══════════════════════════════════════════════════════════════ */

@keyframes ry-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes ry-fade-out {
  from { opacity: 1; }
  to { opacity: 0; }
}

@keyframes ry-slide-up {
  from { transform: translateY(1rem); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

@keyframes ry-slide-down {
  from { transform: translateY(-1rem); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

@keyframes ry-scale-in {
  from { transform: scale(0.95); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

/* ═══════════════════════════════════════════════════════════════
   SWITCH
   ═══════════════════════════════════════════════════════════════ */

ry-switch {
  display: inline-flex;
  align-items: center;
  gap: var(--ry-space-3);
  cursor: pointer;
  user-select: none;
}

ry-switch[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.ry-switch__track {
  position: relative;
  display: inline-flex;
  width: 2.75rem;
  height: 1.5rem;
  flex-shrink: 0;

  background-color: var(--ry-color-bg-muted);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-full);

  transition: background-color var(--ry-duration-fast) var(--ry-ease),
              border-color var(--ry-duration-fast) var(--ry-ease);
}

ry-switch[checked] .ry-switch__track {
  background-color: var(--ry-color-primary);
  border-color: var(--ry-color-primary);
}

.ry-switch__thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 1.125rem;
  height: 1.125rem;

  background-color: var(--ry-color-bg);
  border-radius: var(--ry-radius-full);
  box-shadow: var(--ry-shadow-sm);

  transition: transform var(--ry-duration-fast) var(--ry-ease);
}

ry-switch[checked] .ry-switch__thumb {
  transform: translateX(1.25rem);
}

.ry-switch__label {
  font-size: var(--ry-text-sm);
  font-weight: var(--ry-font-medium);
  color: var(--ry-color-text);
}

.ry-switch__input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

ry-switch:focus-visible {
  outline: none;
}

ry-switch:focus-visible .ry-switch__track {
  box-shadow: var(--ry-focus-ring);
}

/* ═══════════════════════════════════════════════════════════════
   TOOLTIP
   ═══════════════════════════════════════════════════════════════ */

ry-tooltip {
  position: relative;
  display: inline-block;
}

.ry-tooltip__content {
  position: absolute;
  z-index: var(--ry-z-tooltip);

  padding: var(--ry-space-2) var(--ry-space-3);

  font-size: var(--ry-text-xs);
  font-weight: var(--ry-font-medium);
  line-height: var(--ry-leading-tight);
  white-space: nowrap;

  background-color: var(--ry-color-text);
  color: var(--ry-color-text-inverse);
  border-radius: var(--ry-radius-md);

  opacity: 0;
  visibility: hidden;
  pointer-events: none;

  transition: opacity var(--ry-duration-fast) var(--ry-ease),
              visibility var(--ry-duration-fast) var(--ry-ease);
}

ry-tooltip[data-ry-state="open"] .ry-tooltip__content {
  opacity: 1;
  visibility: visible;
}

/* Position offsets */
ry-tooltip[data-ry-position="top"] .ry-tooltip__content {
  margin-bottom: var(--ry-space-2);
}

ry-tooltip[data-ry-position="bottom"] .ry-tooltip__content {
  margin-top: var(--ry-space-2);
}

ry-tooltip[data-ry-position="left"] .ry-tooltip__content {
  margin-right: var(--ry-space-2);
}

ry-tooltip[data-ry-position="right"] .ry-tooltip__content {
  margin-left: var(--ry-space-2);
}

/* ═══════════════════════════════════════════════════════════════
   DRAWER
   ═══════════════════════════════════════════════════════════════ */

ry-drawer {
  display: contents;
}

.ry-drawer__backdrop {
  position: fixed;
  inset: 0;
  z-index: var(--ry-z-modal-backdrop);
  background-color: var(--ry-color-overlay);

  opacity: 0;
  visibility: hidden;
  transition: opacity var(--ry-duration-normal) var(--ry-ease),
              visibility var(--ry-duration-normal) var(--ry-ease);
}

ry-drawer[data-ry-state="open"] .ry-drawer__backdrop {
  opacity: 1;
  visibility: visible;
}

.ry-drawer__panel {
  position: fixed;
  z-index: var(--ry-z-modal);

  background-color: var(--ry-color-bg);
  box-shadow: var(--ry-shadow-xl);

  opacity: 0;
  visibility: hidden;
  transition: opacity var(--ry-duration-normal) var(--ry-ease),
              visibility var(--ry-duration-normal) var(--ry-ease),
              transform var(--ry-duration-normal) var(--ry-ease);
}

ry-drawer[data-ry-state="open"] .ry-drawer__panel {
  opacity: 1;
  visibility: visible;
}

/* Left drawer */
.ry-drawer__panel[data-ry-side="left"] {
  top: 0;
  left: 0;
  bottom: 0;
  width: 20rem;
  max-width: 100%;
  transform: translateX(-100%);
}

ry-drawer[data-ry-state="open"] .ry-drawer__panel[data-ry-side="left"] {
  transform: translateX(0);
}

/* Right drawer */
.ry-drawer__panel[data-ry-side="right"] {
  top: 0;
  right: 0;
  bottom: 0;
  width: 20rem;
  max-width: 100%;
  transform: translateX(100%);
}

ry-drawer[data-ry-state="open"] .ry-drawer__panel[data-ry-side="right"] {
  transform: translateX(0);
}

/* Top drawer */
.ry-drawer__panel[data-ry-side="top"] {
  top: 0;
  left: 0;
  right: 0;
  height: auto;
  max-height: 80vh;
  transform: translateY(-100%);
}

ry-drawer[data-ry-state="open"] .ry-drawer__panel[data-ry-side="top"] {
  transform: translateY(0);
}

/* Bottom drawer */
.ry-drawer__panel[data-ry-side="bottom"] {
  bottom: 0;
  left: 0;
  right: 0;
  height: auto;
  max-height: 80vh;
  border-radius: var(--ry-radius-xl) var(--ry-radius-xl) 0 0;
  transform: translateY(100%);
}

ry-drawer[data-ry-state="open"] .ry-drawer__panel[data-ry-side="bottom"] {
  transform: translateY(0);
}

.ry-drawer__close {
  position: absolute;
  top: var(--ry-space-4);
  right: var(--ry-space-4);

  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;

  font-size: var(--ry-text-xl);
  background: transparent;
  border: none;
  border-radius: var(--ry-radius-md);
  color: var(--ry-color-text-muted);
  cursor: pointer;

  transition: background-color var(--ry-duration-fast) var(--ry-ease),
              color var(--ry-duration-fast) var(--ry-ease);
}

.ry-drawer__close:hover {
  background-color: var(--ry-color-bg-muted);
  color: var(--ry-color-text);
}

.ry-drawer__content {
  padding: var(--ry-space-6);
  padding-top: var(--ry-space-12);
  overflow-y: auto;
  height: 100%;
}

/* ═══════════════════════════════════════════════════════════════
   TOAST
   ═══════════════════════════════════════════════════════════════ */

.ry-toast-container {
  position: fixed;
  top: var(--ry-space-4);
  right: var(--ry-space-4);
  z-index: var(--ry-z-toast);

  display: flex;
  flex-direction: column;
  gap: var(--ry-space-3);

  max-width: 24rem;
  pointer-events: none;
}

ry-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--ry-space-3);

  padding: var(--ry-space-4);

  font-family: var(--ry-font-sans);
  background-color: var(--ry-color-bg);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-lg);
  box-shadow: var(--ry-shadow-lg);

  pointer-events: auto;

  opacity: 0;
  transform: translateX(1rem);
  transition: opacity var(--ry-duration-normal) var(--ry-ease),
              transform var(--ry-duration-normal) var(--ry-ease);
}

ry-toast[data-ry-state="visible"] {
  opacity: 1;
  transform: translateX(0);
}

ry-toast[data-ry-state="hiding"] {
  opacity: 0;
  transform: translateX(1rem);
}

.ry-toast__icon {
  flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--ry-text-sm);
}

ry-toast[type="info"] .ry-toast__icon {
  color: #06b6d4;
}

ry-toast[type="success"] .ry-toast__icon {
  color: var(--ry-color-success);
}

ry-toast[type="warning"] .ry-toast__icon {
  color: var(--ry-color-warning);
}

ry-toast[type="error"] .ry-toast__icon {
  color: var(--ry-color-danger);
}

.ry-toast__content {
  flex: 1;
  font-size: var(--ry-text-sm);
  color: var(--ry-color-text);
  line-height: var(--ry-leading-normal);
}

.ry-toast__close {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  margin: calc(var(--ry-space-1) * -1);

  font-size: var(--ry-text-lg);
  background: transparent;
  border: none;
  border-radius: var(--ry-radius-sm);
  color: var(--ry-color-text-muted);
  cursor: pointer;

  transition: background-color var(--ry-duration-fast) var(--ry-ease),
              color var(--ry-duration-fast) var(--ry-ease);
}

.ry-toast__close:hover {
  background-color: var(--ry-color-bg-muted);
  color: var(--ry-color-text);
}

/* ═══════════════════════════════════════════════════════════════
   SELECT
   ═══════════════════════════════════════════════════════════════ */

ry-select {
  position: relative;
  display: inline-block;
  min-width: 12rem;
}

ry-select[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.ry-select__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ry-space-2);

  width: 100%;
  padding: var(--ry-space-2) var(--ry-space-3);

  font-family: var(--ry-font-sans);
  font-size: var(--ry-text-base);
  line-height: var(--ry-leading-normal);

  background-color: var(--ry-color-bg);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-md);

  cursor: pointer;

  transition: border-color var(--ry-duration-fast) var(--ry-ease),
              box-shadow var(--ry-duration-fast) var(--ry-ease);
}

ry-select:hover .ry-select__trigger {
  border-color: var(--ry-color-border-strong);
}

ry-select:focus-visible .ry-select__trigger {
  outline: none;
  border-color: var(--ry-color-primary);
  box-shadow: var(--ry-focus-ring);
}

ry-select[data-ry-state="open"] .ry-select__trigger {
  border-color: var(--ry-color-primary);
}

.ry-select__value {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--ry-color-text-muted);
}

.ry-select__value--selected {
  color: var(--ry-color-text);
}

.ry-select__arrow {
  flex-shrink: 0;
  font-size: var(--ry-text-xs);
  color: var(--ry-color-text-muted);
  transition: transform var(--ry-duration-fast) var(--ry-ease);
}

ry-select[data-ry-state="open"] .ry-select__arrow {
  transform: rotate(180deg);
}

.ry-select__dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: var(--ry-z-dropdown);

  margin-top: var(--ry-space-1);
  padding: var(--ry-space-1);
  max-height: 15rem;
  overflow-y: auto;

  background-color: var(--ry-color-bg);
  border: var(--ry-border-width) solid var(--ry-color-border);
  border-radius: var(--ry-radius-lg);
  box-shadow: var(--ry-shadow-lg);

  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.5rem);
  transition: opacity var(--ry-duration-fast) var(--ry-ease),
              visibility var(--ry-duration-fast) var(--ry-ease),
              transform var(--ry-duration-fast) var(--ry-ease);
}

ry-select[data-ry-state="open"] .ry-select__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Dropdown flipped to top when near bottom of screen */
ry-select[data-ry-position="top"] .ry-select__dropdown {
  top: auto;
  bottom: 100%;
  margin-top: 0;
  margin-bottom: var(--ry-space-1);
  transform: translateY(0.5rem);
}

ry-select[data-ry-position="top"][data-ry-state="open"] .ry-select__dropdown {
  transform: translateY(0);
}

.ry-select__option {
  padding: var(--ry-space-2) var(--ry-space-3);

  font-size: var(--ry-text-sm);
  color: var(--ry-color-text);

  border-radius: var(--ry-radius-md);
  cursor: pointer;

  transition: background-color var(--ry-duration-fast) var(--ry-ease);
}

.ry-select__option:hover,
.ry-select__option[data-highlighted] {
  background-color: var(--ry-color-bg-muted);
}

.ry-select__option[aria-selected="true"] {
  background-color: var(--ry-color-primary);
  color: var(--ry-color-text-inverse);
}

.ry-select__option[data-disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.ry-select__option[data-disabled]:hover {
  background-color: transparent;
}

.ry-select__native {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* Hide placeholder ry-option elements */
ry-option {
  display: none;
}
