/* ── Buttons ── */
.pg-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 1.5px solid transparent;
  border-radius: var(--radius-pill);
  padding: 0.6rem 1.2rem;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease,
              color 0.15s ease, transform 0.1s ease;
  white-space: nowrap;
  line-height: 1;
}
.pg-button:active { transform: translateY(1px); }
.pg-button:hover  { text-decoration: none; }

/* Primary — light fill, dark text, red on hover */
.pg-button-primary {
  background: var(--color-light);
  border-color: var(--color-light);
  color: var(--color-dark);
  font-weight: 600;
}
.pg-button-primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--color-light);
}

/* Ghost — subtle outline */
.pg-button-ghost {
  background: transparent;
  border-color: var(--border);
  color: var(--text-muted);
}
.pg-button-ghost:hover {
  border-color: rgba(241, 232, 230, 0.35);
  color: var(--text);
  background: rgba(241, 232, 230, 0.05);
}

/* Danger */
.pg-button-danger {
  background: transparent;
  border-color: var(--danger);
  color: var(--danger);
}
.pg-button-danger:hover {
  background: var(--danger);
  color: var(--color-light);
}

/* ── Score / brand highlight ── */
.pg-score,
.pg-paris { color: var(--accent); font-weight: 700; }

/* ── Photos ── */
.pg-photo {
  max-width: 100%;
  max-height: 80vh;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  cursor: zoom-in;
}

/* ── Map ── */
#map {
  width: 100%;
  height: 100px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}

/* ── Form inputs (global dark style) ── */
input[type="text"],
input[type="email"],
input[type="password"],
textarea,
select {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: var(--text-md);
  padding: 0.55rem 0.75rem;
  width: 100%;
  transition: border-color 0.15s ease;
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: rgba(241, 232, 230, 0.4);
}
input::placeholder, textarea::placeholder { color: var(--text-muted); }