/* ============================================================
   CountrySelect  —  cs-* namespace
   ============================================================ */

/* ── Root wrapper ─────────────────────────────────────────── */

.cs-root {
  position: relative;
  width: 100%;
}

/* ── Trigger button ───────────────────────────────────────── */

.cs-trigger {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
}

.cs-trigger__text {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  color: var(--clr-text-base);
}

.cs-trigger__placeholder {
  flex: 1;
  font-size: 13.5px;
  color: var(--clr-text-faint);
}

/* ── Chevron icon ─────────────────────────────────────────── */

.cs-chevron {
  flex-shrink: 0;
  color: var(--clr-text-muted);
  transition: transform 0.18s ease, color var(--trans-fast);
  margin-inline-start: auto;
}

.cs-chevron--up {
  transform: rotate(180deg);
  color: var(--clr-blue);
}

/* ── Flag image ───────────────────────────────────────────── */

.cs-flag {
  width: 22px;
  height: 15px;
  object-fit: cover;
  border-radius: 3px;
  flex-shrink: 0;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

/* ── Dropdown panel ───────────────────────────────────────── */

.cs-dropdown {
  position: absolute;
  z-index: 999;
  top: calc(100% + 6px);
  inset-inline-start: 0;
  inset-inline-end: 0;
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border-mid);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.13), 0 2px 8px rgba(0, 0, 0, 0.06);
  max-height: 260px;
  overflow-y: auto;
  animation: cs-fade-in 0.14s ease;
}

@keyframes cs-fade-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* scrollbar */
.cs-dropdown::-webkit-scrollbar {
  width: 5px;
}
.cs-dropdown::-webkit-scrollbar-track {
  background: transparent;
}
.cs-dropdown::-webkit-scrollbar-thumb {
  background: var(--clr-border-mid);
  border-radius: 10px;
}

/* ── Option row ───────────────────────────────────────────── */

.cs-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  cursor: pointer;
  transition: background 0.1s;
  border-radius: 0;
}

.cs-option:first-child {
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}

.cs-option:last-child {
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.cs-option:hover {
  background: var(--clr-blue-hover);
}

.cs-option--placeholder {
  color: var(--clr-text-faint);
  font-size: 13px;
  border-bottom: 1px solid var(--clr-border-light);
  padding-bottom: 10px;
}

.cs-option--placeholder:hover {
  background: var(--clr-bg-muted);
}

.cs-option--selected {
  background: var(--clr-blue-light);
}

.cs-option--selected:hover {
  background: var(--clr-blue-hover);
}

.cs-option__label {
  flex: 1;
  font-size: 13.5px;
  color: var(--clr-text-base);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cs-option--selected .cs-option__label {
  font-weight: 600;
  color: var(--clr-blue);
}

.cs-option__check {
  flex-shrink: 0;
  color: var(--clr-blue);
  margin-inline-start: auto;
}
