/**
 * FlowGrip UI components (built on tokens.css)
 * Spec: /docs/design/components.md
 */

/* --- Buttons --- */
.fg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-weight: 500;
  line-height: 1.25;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color var(--duration-fast) ease, border-color var(--duration-fast) ease, color var(--duration-fast) ease;
  text-decoration: none;
  white-space: nowrap;
}

.fg-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

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

.fg-btn--sm {
  font-size: var(--font-size-body);
  padding: var(--space-2) var(--space-3);
  min-height: 2.25rem;
}

.fg-btn--md {
  font-size: var(--font-size-label);
  padding: var(--space-2) var(--space-4);
  min-height: var(--input-min-height);
}

.fg-btn--block {
  width: 100%;
}

.fg-btn--primary {
  background-color: var(--color-primary);
  color: var(--color-primary-text);
}

.fg-btn--primary:hover:not(:disabled) {
  background-color: var(--color-primary-hover);
}

.fg-btn--secondary {
  background-color: var(--color-bg-surface);
  color: var(--color-text-primary);
  border-color: var(--color-border);
}

.fg-btn--secondary:hover:not(:disabled) {
  background-color: var(--color-bg-muted);
}

.fg-btn--destructive {
  background-color: var(--color-destructive);
  color: var(--color-destructive-text);
}

.fg-btn--destructive:hover:not(:disabled) {
  background-color: var(--color-destructive-hover);
}

.fg-btn--ghost {
  background-color: transparent;
  color: var(--color-text-secondary);
}

.fg-btn--ghost:hover:not(:disabled) {
  background-color: var(--color-bg-muted);
  color: var(--color-text-primary);
}

.fg-btn--link {
  background: none;
  border: none;
  color: var(--color-primary);
  padding: 0;
  min-height: auto;
  font-weight: 500;
}

.fg-btn--link:hover:not(:disabled) {
  text-decoration: underline;
}

.fg-btn--warning {
  background-color: var(--color-warning);
  color: var(--color-warning-text-btn);
}

.fg-btn--warning:hover:not(:disabled) {
  background-color: var(--color-warning-hover);
}

.fg-btn--soft {
  background: linear-gradient(180deg, var(--color-primary-muted-bg) 0%, var(--color-primary-muted-bg-end) 100%);
  color: var(--color-primary-muted-text);
  border-color: var(--color-primary-muted-border);
  font-weight: 600;
}

.fg-btn--soft:hover:not(:disabled) {
  background: linear-gradient(180deg, var(--color-primary-muted-bg-end) 0%, var(--color-primary-muted-border) 100%);
  border-color: var(--color-primary-muted-border-hover);
  color: var(--color-primary-muted-text-strong);
}

a.fg-btn {
  text-decoration: none;
}

.fg-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: var(--touch-target-min);
  min-height: var(--touch-target-min);
  padding: var(--space-2);
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: inherit;
  cursor: pointer;
  transition: background-color var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-icon-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.fg-icon-btn--destructive {
  color: var(--color-destructive);
}

.fg-icon-btn--destructive:hover {
  color: var(--color-destructive-hover);
  background-color: var(--color-danger-bg);
}

/* --- Form fields (v2 — custom controls, no native chrome) --- */
.fg-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.fg-label {
  font-family: var(--font-sans);
  font-size: var(--font-size-label);
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-text-primary);
}

.fg-label--optional::after {
  content: " (opcional)";
  font-weight: 400;
  color: var(--color-text-secondary);
}

.fg-field__hint {
  font-size: var(--font-size-caption);
  color: var(--color-text-secondary);
  line-height: 1.4;
}

.fg-input,
.fg-select,
.fg-textarea {
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font-sans);
  font-size: var(--font-size-body);
  line-height: 1.5;
  color: var(--color-text-primary);
  background-color: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--input-radius, var(--radius-md));
  padding: var(--space-2) var(--space-3);
  min-height: var(--input-min-height);
  box-shadow: var(--input-shadow, none);
  transition:
    border-color var(--duration-fast) ease,
    box-shadow var(--duration-fast) ease,
    background-color var(--duration-fast) ease;
}

.fg-textarea {
  min-height: 5rem;
  resize: vertical;
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
}

.fg-input::placeholder,
.fg-textarea::placeholder {
  color: var(--color-text-secondary);
  opacity: 0.85;
}

.fg-input:hover:not(:disabled):not([readonly]):not(:focus),
.fg-select:hover:not(:disabled):not(:focus),
.fg-textarea:hover:not(:disabled):not([readonly]):not(:focus) {
  border-color: var(--input-border-hover, var(--color-text-secondary));
}

.fg-input:focus,
.fg-select:focus,
.fg-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--input-shadow-focus, 0 0 0 3px var(--color-focus-ring));
}

.fg-input:disabled,
.fg-textarea:disabled,
.fg-select:disabled {
  background-color: var(--color-bg-muted);
  color: var(--color-text-secondary);
  cursor: not-allowed;
  opacity: 0.75;
  box-shadow: none;
}

.fg-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 2.75rem;
  cursor: pointer;
  background-image: var(--select-chevron);
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
}

.fg-select:disabled {
  background-image: var(--select-chevron);
}

.fg-select option {
  color: var(--color-text-primary);
  background-color: var(--color-bg-surface);
}

.fg-input[type="date"],
.fg-input[type="time"],
.fg-input[type="datetime-local"],
.fg-input[type="number"] {
  font-variant-numeric: tabular-nums;
}

.fg-input[type="date"]::-webkit-calendar-picker-indicator,
.fg-input[type="time"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: 0.55;
  filter: none;
}

.fg-input[type="date"]:hover::-webkit-calendar-picker-indicator,
.fg-input[type="time"]:hover::-webkit-calendar-picker-indicator {
  opacity: 0.85;
}

.fg-input--tabular {
  font-variant-numeric: tabular-nums;
}

/* intl-tel-input inside fg-field */
.fg-field .iti {
  width: 100%;
  display: block;
}

.fg-field .iti .fg-input,
.fg-field .iti input[type="tel"] {
  width: 100%;
  padding-left: 3.25rem;
}

.fg-field .iti__flag-container {
  border-right: 1px solid var(--color-border);
}

.fg-field .iti__selected-flag {
  padding: 0 var(--space-2) 0 var(--space-3);
  border-radius: var(--input-radius, var(--radius-md)) 0 0 var(--input-radius, var(--radius-md));
  background-color: var(--color-bg-muted);
}

.fg-field .iti__selected-flag:hover,
.fg-field .iti__selected-flag:focus {
  background-color: var(--color-bg-muted);
}

.fg-field .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag {
  background-color: var(--color-bg-muted);
}

.fg-field .iti__country-list {
  z-index: 110;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  background-color: var(--color-bg-surface);
}

.fg-field .iti__country.iti__highlight {
  background-color: var(--color-info-bg);
}

.fg-field--invalid .fg-input,
.fg-field--invalid .fg-select,
.fg-field--invalid .fg-textarea {
  border-color: var(--color-destructive);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.15);
}

/* --- Badges --- */
.fg-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.625rem;
  font-family: var(--font-sans);
  font-size: var(--font-size-caption);
  font-weight: 600;
  line-height: 1.25;
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.fg-badge--success {
  background-color: var(--color-success-bg);
  color: var(--color-success-text);
}

.fg-badge--warning {
  background-color: var(--color-warning-bg);
  color: var(--color-warning-text);
}

.fg-badge--danger {
  background-color: var(--color-danger-bg);
  color: var(--color-danger-text);
}

.fg-badge--info {
  background-color: var(--color-info-bg);
  color: var(--color-info-text);
}

.fg-badge--neutral {
  background-color: var(--color-bg-muted);
  color: var(--color-text-primary);
}

.fg-badge--bono {
  background-color: var(--color-bono-bg);
  color: var(--color-bono-text);
}

/* --- Token text / surface utilities (backoffice Tailwind color migration) --- */
.fg-text-primary {
  color: var(--color-text-primary);
}

.fg-text-secondary {
  color: var(--color-text-secondary);
}

.fg-text-subtle {
  color: var(--color-text-secondary);
  opacity: 0.85;
}

.fg-text-destructive {
  color: var(--color-destructive);
}

.fg-text-success {
  color: var(--color-success);
}

.fg-text-warning {
  color: var(--color-warning);
}

.fg-text-link {
  color: var(--color-primary);
}

.fg-bg-muted {
  background-color: var(--color-bg-muted);
}

.fg-bg-surface {
  background-color: var(--color-bg-surface);
}

.fg-bg-info-subtle {
  background-color: var(--color-info-bg);
}

.fg-bg-danger-subtle {
  background-color: var(--color-danger-bg);
}

.fg-bg-success-subtle {
  background-color: var(--color-success-bg);
}

.fg-bg-warning-subtle {
  background-color: var(--color-warning-bg);
}

.fg-border-color {
  border-color: var(--color-border);
}

.fg-divide-y > :not([hidden]) ~ :not([hidden]) {
  border-top-width: 1px;
  border-top-style: solid;
  border-top-color: var(--color-border);
}

.fg-interactive-row {
  transition: background-color var(--duration-fast) ease;
}

.fg-interactive-row:hover {
  background-color: var(--color-bg-muted);
}

.fg-link-destructive {
  color: var(--color-destructive);
  text-decoration: none;
  transition: color var(--duration-fast) ease;
}

.fg-link-destructive:hover {
  color: var(--color-destructive-hover);
}

.fg-file-input::file-selector-button {
  margin-right: var(--space-4);
  padding: var(--space-2) var(--space-4);
  border: none;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-body);
  font-weight: 600;
  background-color: var(--color-info-bg);
  color: var(--color-info-text);
  cursor: pointer;
  transition: background-color var(--duration-fast) ease;
}

.fg-file-input:hover::file-selector-button {
  background-color: color-mix(in srgb, var(--color-info-bg) 70%, var(--color-primary-muted-border));
}

/* Legacy badge aliases (custom.css compatibility) */
.badge-success { background-color: var(--color-success-bg); color: var(--color-success-text); }
.badge-warning { background-color: var(--color-warning-bg); color: var(--color-warning-text); }
.badge-danger { background-color: var(--color-danger-bg); color: var(--color-danger-text); }
.badge-info { background-color: var(--color-info-bg); color: var(--color-info-text); }

/* --- Alerts --- */
.fg-alert {
  font-family: var(--font-sans);
  font-size: var(--font-size-body);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  margin-bottom: var(--space-4);
}

.fg-alert--error {
  background-color: var(--color-danger-bg);
  border-color: #f87171;
  color: var(--color-danger-text);
}

.fg-alert--success {
  background-color: var(--color-success-bg);
  border-color: #6ee7b7;
  color: var(--color-success-text);
}

.fg-alert--warning {
  background-color: var(--color-warning-bg);
  border-color: #fcd34d;
  color: var(--color-warning-text);
}

.fg-alert--info {
  background-color: var(--color-info-bg);
  border-color: #93c5fd;
  color: var(--color-info-text);
}

[data-surface="portal-guest"] .fg-alert--error,
[data-surface="portal"] .fg-alert--error {
  background-color: rgba(127, 29, 29, 0.4);
  border-color: #991b1b;
  color: #fecaca;
}

[data-surface="portal-guest"] .fg-alert--success,
[data-surface="portal"] .fg-alert--success {
  background-color: rgba(6, 78, 59, 0.4);
  border-color: #065f46;
  color: #a7f3d0;
}

/* --- Portal surfaces --- */
.fg-portal-nav {
  background-color: var(--color-portal-nav);
  border-bottom: 1px solid var(--color-portal-nav-border);
  color: var(--color-portal-nav-text);
}

.fg-portal-guest-card {
  background-color: color-mix(in srgb, var(--color-bg-surface) 80%, transparent);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: var(--space-6);
}

.fg-portal-nav-link {
  font-family: var(--font-sans);
  font-size: var(--font-size-body);
  font-weight: 500;
  color: var(--color-portal-link, var(--color-portal-nav));
  text-decoration: none;
}

.fg-portal-nav-link:hover {
  color: var(--color-portal-link-hover, var(--color-primary-hover));
}

.fg-portal-weekday {
  display: block;
  padding: var(--space-2);
  border-radius: var(--radius-md);
  text-align: center;
  text-decoration: none;
  border: 1px solid transparent;
  transition: background-color var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-portal-weekday__name {
  display: block;
  font-size: var(--font-size-caption);
  font-weight: 500;
}

.fg-portal-weekday__num {
  display: block;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.25;
}

.fg-portal-weekday--active {
  background-color: var(--color-portal-nav);
  color: var(--color-portal-nav-text);
  border-color: var(--color-portal-nav);
}

.fg-portal-weekday--today {
  border-color: var(--color-text-secondary);
  color: var(--color-text-primary);
  font-weight: 500;
}

.fg-portal-weekday--default {
  color: var(--color-text-secondary);
}

.fg-portal-weekday--default:hover {
  background-color: var(--color-bg-muted);
}

.fg-portal-sheet {
  background-color: var(--color-bg-surface);
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
  box-shadow: var(--shadow-md);
}

.fg-portal-card {
  display: block;
  padding: var(--space-4);
  background-color: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: border-color var(--duration-fast) ease, background-color var(--duration-fast) ease;
}

.fg-portal-card:hover {
  border-color: color-mix(in srgb, var(--color-portal-nav) 45%, var(--color-border));
  background-color: var(--color-bg-muted);
}

.fg-portal-card__title {
  font-weight: 500;
  color: var(--color-text-primary);
}

.fg-portal-card__desc {
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  margin: var(--space-1) 0 0;
}

.fg-portal-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  flex: 1 1 0;
  padding: var(--space-2);
  border-radius: var(--radius-full);
  font-size: var(--font-size-body);
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  background-color: var(--color-bg-muted);
  color: var(--color-text-primary);
  transition: background-color var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-portal-chip:hover {
  background-color: var(--color-border);
}

.fg-portal-chip--active {
  background-color: var(--color-primary);
  color: var(--color-primary-text);
}

.fg-portal-chip--active:hover {
  background-color: var(--color-primary-hover);
}

.fg-portal-fab {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  z-index: 45;
  width: 3rem;
  height: 3rem;
  border-radius: var(--radius-full);
  background-color: var(--color-primary);
  color: var(--color-primary-text);
  border: none;
  box-shadow: var(--shadow-md);
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color var(--duration-fast) ease;
}

.fg-portal-fab:hover {
  background-color: var(--color-primary-hover);
}

.fg-portal-toggle {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  min-height: 3.25rem;
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-surface);
  color: var(--color-text-primary);
  font-size: var(--font-size-caption);
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--duration-fast) ease, background-color var(--duration-fast) ease, border-color var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-portal-toggle:hover {
  background-color: var(--color-bg-muted);
  box-shadow: var(--shadow-md);
}

.fg-portal-toggle--active {
  background-color: var(--color-portal-nav);
  border-color: var(--color-portal-nav);
  color: var(--color-portal-nav-text);
}

.fg-btn.fg-portal-btn--nav {
  background-color: var(--color-portal-nav);
  color: var(--color-portal-nav-text);
  border-color: var(--color-portal-nav);
}

.fg-btn.fg-portal-btn--nav:hover:not(:disabled) {
  background-color: color-mix(in srgb, var(--color-portal-nav) 85%, black);
}

.fg-portal-option {
  text-align: left;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  border: 2px solid var(--color-border);
  font-weight: 500;
  color: var(--color-text-primary);
  background: var(--color-bg-surface);
  transition: border-color var(--duration-fast) ease, background-color var(--duration-fast) ease;
}

.fg-portal-option:hover {
  border-color: var(--color-text-secondary);
}

.fg-portal-option--selected {
  border-color: var(--color-portal-nav);
  background-color: color-mix(in srgb, var(--color-portal-nav) 10%, white);
  color: var(--color-portal-nav);
}

.fg-portal-timeline-month {
  font-size: var(--font-size-caption);
  font-weight: 600;
  color: var(--color-portal-nav);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.fg-portal-body {
  background-color: var(--color-bg-page);
  color: var(--color-text-primary);
  min-height: 100vh;
  padding-bottom: 5rem;
}

.fg-portal-payment-banner {
  position: sticky;
  top: 3.75rem;
  z-index: 40;
  background: var(--color-destructive);
  color: var(--color-destructive-text, #ffffff);
  text-align: center;
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-sm, 0.8125rem);
  font-weight: 500;
}

.fg-portal-bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 40;
  padding: var(--space-2) var(--space-4);
  padding-bottom: max(1.5rem, env(safe-area-inset-bottom));
  background: var(--color-bg-surface);
  border-top: 1px solid var(--color-border);
}

.fg-portal-bottom-nav__inner {
  max-width: 56rem;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-around;
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  box-shadow: var(--shadow-sm);
  padding: var(--space-2) 0;
  background: var(--color-bg-surface);
}

.fg-portal-bottom-nav__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.125rem;
  padding: var(--space-2) var(--space-4);
  border-radius: 0.75rem;
  font-size: 0.75rem;
  line-height: 1.25;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition:
    color var(--duration-fast) ease,
    background-color var(--duration-fast) ease;
}

.fg-portal-bottom-nav__item:hover {
  color: var(--color-text-primary);
}

.fg-portal-bottom-nav__item--active {
  background: color-mix(in srgb, var(--color-portal-nav) 15%, transparent);
  color: var(--color-portal-nav);
  font-weight: 500;
}

.fg-portal-bottom-nav__item svg {
  width: 1.5rem;
  height: 1.5rem;
}

.fg-portal-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  overflow: hidden;
  background: var(--overlay-bg);
}

.fg-portal-overlay__panel {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--color-bg-surface);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  box-shadow: var(--shadow-md);
}

.fg-portal-overlay--centered {
  overflow-y: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

/* --- Podio (portal) --- */
.fg-podium-hero {
  position: relative;
}

.fg-podium-hero__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.fg-podium-hero__title {
  margin: 0;
  font-size: var(--font-size-h1);
  font-weight: 600;
  color: var(--color-text-primary);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.fg-podium-help-btn {
  position: absolute;
  bottom: var(--space-2);
  right: var(--space-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: var(--radius-full);
  border: none;
  background: var(--color-bg-muted);
  box-shadow: var(--shadow-sm);
  font-size: 0.75rem;
  cursor: pointer;
  transition: background-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;
}

.fg-podium-help-btn:hover {
  background: var(--color-border);
  box-shadow: var(--shadow-md);
}

.fg-podium-chip-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.fg-podium-chip-row--tight {
  margin-top: var(--space-2);
}

.fg-podium-chip {
  display: inline-flex;
  align-items: center;
  border-radius: var(--radius-full);
  padding: 0.25rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.25;
}

.fg-podium-chip--week {
  background: var(--color-info-bg);
  color: var(--color-info-text);
}

.fg-podium-chip--gold {
  background: #fef9c3;
  color: #854d0e;
}

.fg-podium-chip--silver {
  background: var(--color-bg-muted);
  color: var(--color-text-secondary);
}

.fg-podium-chip--bronze {
  background: #ffedd5;
  color: #9a3412;
}

.fg-podium-chip--top5 {
  background: #e0f2fe;
  color: #075985;
}

.fg-podium-chip--points {
  background: color-mix(in srgb, var(--color-portal-nav) 12%, white);
  color: var(--color-portal-nav);
}

.fg-podium-chip--streak-seed {
  background: var(--color-bg-muted);
  color: var(--color-text-secondary);
}

.fg-podium-chip--streak-warm {
  background: #fef9c3;
  color: #854d0e;
}

.fg-podium-chip--streak-good {
  background: #d1fae5;
  color: #047857;
}

.fg-podium-chip--streak-strong {
  background: #e0f2fe;
  color: #0369a1;
}

.fg-podium-chip--streak-intense {
  background: #e0e7ff;
  color: #4338ca;
}

.fg-podium-chip--streak-hot {
  background: #f3e8ff;
  color: #6b21a8;
}

.fg-podium-chip--streak-legend {
  background: #fae8ff;
  color: #86198f;
}

.fg-podium-chip--micro {
  padding: 0.125rem 0.5rem;
  font-size: 0.625rem;
}

.fg-podium-chip--class-count {
  border-radius: var(--radius-md);
  border: 1px solid rgba(196, 30, 58, 0.3);
  background: rgba(196, 30, 58, 0.1);
  padding: 0.125rem 0.375rem;
  font-size: 0.625rem;
  font-weight: 500;
  color: #c41e3a;
}

.fg-podium-rules-panel {
  width: 100%;
  max-width: 32rem;
  border-radius: 1rem;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
  padding: var(--space-4);
}

@media (min-width: 640px) {
  .fg-podium-rules-panel {
    padding: var(--space-6);
  }
}

.fg-podium-rules-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.fg-podium-rules-panel__title {
  margin: 0;
  font-size: var(--font-size-h2);
  font-weight: 600;
  color: var(--color-text-primary);
}

.fg-podium-rank-card {
  position: relative;
  border-radius: 1rem;
  border: 1px solid var(--color-border);
  background: var(--color-bg-surface);
  box-shadow: var(--shadow-sm);
  padding: var(--space-3);
  cursor: pointer;
  transition: box-shadow var(--duration-fast) ease;
}

.fg-podium-rank-card:hover {
  box-shadow: var(--shadow-md);
}

.fg-podium-rank-card--1 {
  padding: var(--space-6);
  border-color: #fcd34d;
  background: linear-gradient(to bottom right, #fef9c3, #fde68a);
}

.fg-podium-rank-card--2 {
  padding: var(--space-4);
  border-color: #d1d5db;
  background: linear-gradient(to bottom right, #f3f4f6, #e5e7eb);
}

.fg-podium-rank-card--3 {
  padding: var(--space-4);
  border-color: #fbbf24;
  background: linear-gradient(to bottom right, #fef3c7, #fde68a);
}

.fg-podium-rank-card--4 {
  border-color: #93c5fd;
  background: linear-gradient(to bottom right, #dbeafe, #bfdbfe);
}

.fg-podium-rank-card--5 {
  border-color: #7dd3fc;
  background: linear-gradient(to bottom right, #f0f9ff, #e0f2fe);
}

.fg-podium-rank-badge {
  position: absolute;
  right: var(--space-2);
  top: var(--space-2);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.85);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-secondary);
}

.fg-podium-rank-card--1 .fg-podium-rank-badge {
  width: 2.25rem;
  height: 2.25rem;
  font-size: 1rem;
}

.fg-podium-rank-card--2 .fg-podium-rank-badge,
.fg-podium-rank-card--3 .fg-podium-rank-badge {
  width: 2rem;
  height: 2rem;
  font-size: 0.875rem;
}

.fg-podium-rank-body {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.fg-podium-rank-photo {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  overflow: hidden;
  border-radius: var(--radius-full);
  background: var(--color-bg-muted);
}

.fg-podium-rank-card--1 .fg-podium-rank-photo {
  width: 4rem;
  height: 4rem;
}

.fg-podium-rank-card--2 .fg-podium-rank-photo {
  width: 3.5rem;
  height: 3.5rem;
}

.fg-podium-rank-card--3 .fg-podium-rank-photo {
  width: 3rem;
  height: 3rem;
}

.fg-podium-rank-card--4 .fg-podium-rank-photo,
.fg-podium-rank-card--5 .fg-podium-rank-photo {
  width: 2.75rem;
  height: 2.75rem;
}

.fg-podium-rank-name {
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-right: 2.5rem;
  font-weight: 600;
  color: var(--color-text-primary);
  font-size: var(--font-size-body);
}

.fg-podium-rank-card--1 .fg-podium-rank-name { font-size: 1.5rem; }
.fg-podium-rank-card--2 .fg-podium-rank-name { font-size: 1.25rem; }
.fg-podium-rank-card--3 .fg-podium-rank-name { font-size: 1.125rem; }

.fg-podium-rank-meta {
  margin-top: var(--space-1);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1);
}

.fg-podium-rank-detail {
  margin-top: var(--space-3);
  border-radius: 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.65);
  background: rgba(255, 255, 255, 0.72);
  padding: var(--space-3);
}

.fg-podium-trend {
  position: absolute;
  bottom: var(--space-2);
  right: var(--space-2);
}

.fg-podium-trend--up {
  background: #d1fae5;
  color: #047857;
}

.fg-podium-trend--down {
  background: #ffe4e6;
  color: #be123c;
}

.fg-podium-trend--same {
  background: var(--color-bg-muted);
  color: var(--color-text-secondary);
}

.fg-portal-calendar-nav {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.fg-portal-calendar-nav__year {
  padding: 0 var(--space-2);
  font-size: var(--font-size-caption);
  color: var(--color-text-secondary);
}

/* --- Empty state --- */
.fg-empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--color-text-secondary);
}

.fg-empty__title {
  font-size: var(--font-size-h2);
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--space-2);
}

.fg-empty__message {
  font-size: var(--font-size-body);
  margin: 0 0 var(--space-4);
  max-width: 24rem;
  margin-left: auto;
  margin-right: auto;
}

.fg-empty--compact {
  padding: var(--space-4);
}

.fg-empty--compact .fg-empty__message {
  margin-bottom: 0;
}

.fg-empty__message--spaced {
  margin-bottom: var(--space-5);
}

.fg-empty__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3);
}

/* --- Async loading indicator --- */
.fg-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
}

.fg-loading--overlay {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(248, 250, 252, 0.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.fg-loading__panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-8);
  border-radius: 1.25rem;
  background: var(--color-bg-surface);
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.12);
  max-width: 22rem;
  text-align: center;
}

.fg-loading__dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  height: 2rem;
}

.fg-loading__dots span {
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 9999px;
  background: var(--color-primary, #2563eb);
  animation: fg-loading-dot 1.2s ease-in-out infinite;
}

.fg-loading__dots span:nth-child(2) {
  animation-delay: 0.15s;
}

.fg-loading__dots span:nth-child(3) {
  animation-delay: 0.3s;
}

@keyframes fg-loading-dot {
  0%, 80%, 100% {
    opacity: 0.35;
    transform: scale(0.85) translateY(0);
  }
  40% {
    opacity: 1;
    transform: scale(1) translateY(-4px);
  }
}

.fg-loading__spinner {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 9999px;
  border: 3px solid var(--color-border, #e5e7eb);
  border-top-color: var(--color-primary, #2563eb);
  animation: fg-loading-spin 0.75s linear infinite;
}

.fg-loading__message {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--color-text-secondary, #4b5563);
}

@keyframes fg-loading-spin {
  to { transform: rotate(360deg); }
}

/* --- Modal shell --- */
.fg-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  background-color: var(--overlay-bg);
}

.fg-modal__panel {
  position: relative;
  margin: var(--space-4) auto;
  width: 100%;
  max-width: 56rem;
  background-color: var(--color-bg-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 2rem);
  overflow: visible;
}

.fg-modal__header {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-4) 0;
}

.fg-modal__title {
  font-size: var(--font-size-h2);
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0;
}

.fg-modal__body {
  flex: 1;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: var(--space-4);
}

.fg-modal__footer {
  flex-shrink: 0;
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
  padding: var(--space-4);
  border-top: 1px solid var(--color-border);
}

@media (max-width: 639px) {
  .fg-modal__panel {
    margin: 0;
    min-height: 100vh;
    max-height: none;
    border-radius: 0;
  }

  .fg-modal__footer {
    flex-direction: column;
  }

  .fg-modal__footer .fg-btn {
    width: 100%;
  }
}

/* --- Confirm dialog --- */
.fg-confirm {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background-color: var(--overlay-bg);
}

.fg-confirm.is-open {
  display: flex !important;
}

.fg-confirm__panel {
  width: 100%;
  max-width: 24rem;
  background-color: var(--color-bg-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: var(--space-4);
}

.fg-confirm__panel--wide {
  max-width: 28rem;
}

.fg-confirm__message {
  font-size: var(--font-size-body);
  color: var(--color-text-primary);
  margin: 0 0 var(--space-4);
}

.fg-confirm__message--preline {
  white-space: pre-line;
}

.fg-confirm__message--rich {
  margin-bottom: var(--space-4);
}

.fg-series-end-confirm__title {
  font-size: var(--font-size-body-lg);
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--space-2);
}

.fg-series-end-confirm__lead {
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  margin: 0 0 var(--space-4);
}

.fg-series-end-confirm__section {
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  margin-bottom: var(--space-3);
}

.fg-series-end-confirm__section:last-child {
  margin-bottom: 0;
}

.fg-series-end-confirm__section--safe {
  background-color: var(--color-bg-subtle, #f0fdf4);
  border: 1px solid #bbf7d0;
}

.fg-series-end-confirm__section--change {
  background-color: #fffbeb;
  border: 1px solid #fde68a;
}

.fg-series-end-confirm__section-title {
  font-size: var(--font-size-body-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin: 0 0 var(--space-2);
  color: var(--color-text-primary);
}

.fg-series-end-confirm__section--safe .fg-series-end-confirm__section-title {
  color: #166534;
}

.fg-series-end-confirm__section--change .fg-series-end-confirm__section-title {
  color: #92400e;
}

.fg-series-end-confirm__list {
  margin: 0;
  padding-left: 1.125rem;
  font-size: var(--font-size-body-sm);
  color: var(--color-text-primary);
  line-height: 1.5;
}

.fg-series-end-confirm__list li + li {
  margin-top: var(--space-2);
}

.fg-confirm__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}

.modal-backdrop {
  background-color: var(--overlay-bg);
}

/* --- Tabs (Alpine :class for active state) --- */
.fg-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
}

.fg-tabs__tab {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--font-size-body);
  font-weight: 500;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  text-decoration: none;
  transition: color var(--duration-fast) ease, border-color var(--duration-fast) ease;
}

.fg-tabs__tab:hover {
  color: var(--color-text-primary);
}

.fg-tabs__tab--active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

.fg-tabs__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 0.375rem;
  border-radius: var(--radius-full, 9999px);
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1;
  background-color: #ecfdf5;
  color: #15803d;
}

/* --- Form modal footers --- */
.fg-form-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}

.fg-form-actions--split {
  justify-content: space-between;
  align-items: center;
}

/* Member edit modal — scrollable body + pinned footer */
.fg-member-modal {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.fg-member-modal__scroll {
  flex: 1;
  min-height: 0;
}

.fg-member-modal__footer {
  position: sticky;
  bottom: 0;
  z-index: 20;
  flex-shrink: 0;
  margin: var(--space-4) calc(-1 * var(--space-4)) calc(-1 * var(--space-4));
  padding: var(--space-4);
  background-color: var(--color-bg-surface);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -4px 16px rgba(15, 23, 42, 0.06);
}

.fg-form-section {
  border-bottom: 1px solid var(--color-border);
  padding-bottom: var(--space-2);
  margin-bottom: var(--space-2);
}

.fg-form-section__title {
  font-size: var(--font-size-h2);
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--space-2);
}

.fg-page-header {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.fg-page-header__actions {
  flex-shrink: 0;
}

.fg-page-header__actions .fg-btn {
  width: auto;
  white-space: nowrap;
}

.fg-page-header .fg-page-title {
  margin-bottom: 0;
}

.fg-page-subtitle {
  font-size: 0.875rem;
  color: var(--color-text-secondary, #4b5563);
  margin: var(--space-1) 0 0;
  line-height: 1.5;
}

.fg-link {
  color: var(--color-primary, #b40000);
  font-weight: 500;
  text-decoration: none;
}

.fg-link:hover {
  text-decoration: underline;
}

.fg-attendance-day-summary {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full, 9999px);
  background-color: var(--color-bg-muted, #f3f4f6);
  font-size: 0.8125rem;
  color: var(--color-text-secondary, #6b7280);
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.fg-attendance-day-summary [data-day-pending-count] {
  font-weight: 600;
  color: var(--color-text-primary);
}

.fg-table {
  width: 100%;
  border-collapse: collapse;
}

.fg-table thead {
  background-color: var(--color-bg-muted);
}

.fg-table th {
  padding: var(--space-3);
  text-align: left;
  font-size: var(--font-size-caption);
  font-weight: 500;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.fg-table td {
  padding: var(--space-3);
  font-size: var(--font-size-body);
  color: var(--color-text-primary);
  border-top: 1px solid var(--color-border);
}

.fg-table tbody {
  background-color: var(--color-bg-surface);
}

.fg-table th .sort-header {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  color: inherit;
  text-decoration: none;
}

.fg-table th .sort-header:hover {
  color: var(--color-text-primary);
}

.fg-chart-container {
  position: relative;
  height: 400px;
}

.fg-attendance-section__title {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 var(--space-2);
}

.fg-attendance-section__title--success {
  color: #15803d;
}

.fg-attendance-section__title--danger {
  color: #b91c1c;
}

.fg-attendance-section__title--muted {
  color: var(--color-text-secondary, #9ca3af);
}

.fg-attendance-sections {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.fg-attendance-section__empty {
  grid-column: 1 / -1;
  font-size: 0.875rem;
  color: var(--color-text-secondary, #6b7280);
  margin: 0;
  padding: var(--space-2) 0;
}

@media (max-width: 639px) {
  .fg-form-actions {
    flex-direction: column;
  }

  .fg-form-actions .fg-btn {
    width: 100%;
  }
}

/* --- Backoffice surface --- */
.fg-page-title {
  font-family: var(--font-sans);
  font-size: var(--font-size-display);
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 0;
}

.fg-panel {
  background-color: var(--color-bg-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.fg-panel__header {
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.fg-panel__header--toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.fg-panel__title {
  font-size: var(--font-size-h2);
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0;
}

.fg-panel__title--lg {
  font-size: var(--font-size-h1);
}

.fg-panel__body {
  padding: var(--space-6);
}

.fg-stat-card {
  background-color: var(--color-bg-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
}

.fg-stat-card__label {
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
}

.fg-stat-card__value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
}

.fg-stat-card__value--success {
  color: var(--color-success);
}

.fg-stat-card__value--warning {
  color: var(--color-warning);
}

.fg-stat-card__value--danger {
  color: var(--color-destructive);
}

.fg-stat-card__value--primary {
  color: var(--color-primary);
}

.fg-stat-card__value--accent {
  color: var(--color-primary);
}

.fg-stat-card__meta {
  font-size: var(--font-size-caption);
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
  line-height: 1.5;
}

.fg-pending-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: var(--space-2) var(--space-2) var(--space-4);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  cursor: pointer;
  transition: box-shadow var(--duration-fast) ease;
  background-color: var(--color-bg-surface);
}

.fg-pending-card:hover {
  box-shadow: var(--shadow-md);
}

.fg-pending-card--overdue {
  background-color: var(--color-danger-bg);
  border-color: #fecaca;
}

.fg-pending-card--delayed {
  border-color: #fca5a5;
}

.fg-pending-card__badge {
  width: 100%;
  display: flex;
  justify-content: center;
}

.fg-pending-card:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Pendientes tab skeleton placeholders */
.fg-skeleton-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));
  gap: 1rem;
  padding: 1rem;
}

.fg-skeleton-card {
  height: 12rem;
  border-radius: var(--radius-md);
  background: linear-gradient(
    90deg,
    var(--color-surface-muted, #f3f4f6) 25%,
    #e5e7eb 50%,
    var(--color-surface-muted, #f3f4f6) 75%
  );
  background-size: 200% 100%;
  animation: fg-skeleton-shimmer 1.2s ease-in-out infinite;
}

@keyframes fg-skeleton-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.fg-payment-wizard__student-zone {
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.fg-payment-wizard__student-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.fg-payment-wizard__student-card__photo-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
  width: 5.5rem;
}

.fg-payment-wizard__student-chip {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: var(--color-bg-muted);
  border: 1px solid var(--color-border);
  margin-bottom: var(--space-4);
}

.fg-payment-split-status {
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.fg-payment-split-status--ok {
  color: var(--color-success);
}

.fg-payment-split-status--warn {
  color: var(--color-danger);
}

.fg-payment-split-status--over {
  color: #ea580c;
}

.fg-wizard-footer.is-submitting {
  opacity: 0.7;
  pointer-events: none;
}

/* --- Pagos hub tabs (stepper-style) --- */
.fg-payments-hub-tabs__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.fg-payments-hub-tabs__tab {
  flex: 1 1 auto;
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: var(--touch-target-min);
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-surface);
  color: var(--color-text-secondary);
  font-family: var(--font-sans);
  font-size: var(--font-size-sm);
  font-weight: 500;
  cursor: pointer;
  transition:
    border-color var(--duration-fast) ease,
    background-color var(--duration-fast) ease,
    color var(--duration-fast) ease,
    box-shadow var(--duration-fast) ease;
}

.fg-payments-hub-tabs__tab:hover {
  color: var(--color-text-primary);
  border-color: var(--color-primary-muted-border-hover);
}

.fg-payments-hub-tabs__tab--active {
  border-color: var(--color-primary);
  background: linear-gradient(180deg, var(--color-primary-muted-bg) 0%, var(--color-primary-muted-bg-end) 100%);
  color: var(--color-primary-muted-text);
  box-shadow: var(--shadow-sm);
}

.fg-payments-hub-tabs__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 0.35rem;
  border-radius: 9999px;
  background: var(--color-warning);
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 700;
}

.fg-payments-hub-tabs__tab--active .fg-payments-hub-tabs__count {
  background: var(--color-primary);
}

/* --- Cierre tender method cards --- */
.fg-tender-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-bg-surface);
  box-shadow: var(--shadow-sm);
  transition: transform var(--duration-fast) ease, box-shadow var(--duration-fast) ease;
}

.fg-tender-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.fg-tender-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-md);
}

.fg-tender-card__icon svg {
  width: 1.35rem;
  height: 1.35rem;
}

.fg-tender-card__label {
  font-size: var(--font-size-caption);
  font-weight: 500;
  color: var(--color-text-secondary);
}

.fg-tender-card__value {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
}

.fg-tender-card--cash .fg-tender-card__icon {
  background: #ecfdf5;
  color: #059669;
}

.fg-tender-card--card .fg-tender-card__icon {
  background: var(--color-info-bg);
  color: var(--color-primary);
}

.fg-tender-card--transfer .fg-tender-card__icon {
  background: var(--color-primary-muted-bg);
  color: var(--color-primary);
}

.fg-tender-card--domiciled .fg-tender-card__icon {
  background: #fef3c7;
  color: #d97706;
}

/* POS catalog row */
.fg-pos-item-card {
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-surface);
  transition:
    border-color var(--duration-fast) ease,
    background-color var(--duration-fast) ease,
    box-shadow var(--duration-fast) ease;
}

.fg-pos-item-card:hover {
  border-color: var(--color-primary-muted-border);
  background: var(--color-bg-muted);
  box-shadow: var(--shadow-sm);
}

.fg-cierre-ops__hints li {
  padding-left: 0;
}

.fg-stat-card--success-tint {
  background: linear-gradient(180deg, #ecfdf5 0%, var(--color-bg-surface) 100%);
  border-color: #a7f3d0;
}

.fg-stat-card--warning-tint {
  background: linear-gradient(180deg, #fffbeb 0%, var(--color-bg-surface) 100%);
  border-color: #fde68a;
}

.fg-stat-card--muted {
  background: var(--color-bg-muted);
}

.fg-panel--nested {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-top: var(--space-2);
}

.fg-panel--nested > summary {
  list-style: none;
}

.fg-panel--nested > summary::-webkit-details-marker {
  display: none;
}

/* --- Attendance week --- */
.fg-week-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

.fg-week-nav__label {
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
}

.fg-day-picker {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: var(--space-1);
  text-align: center;
  margin-top: var(--space-3);
}

.fg-day-picker__day {
  position: relative;
  display: block;
  padding: var(--space-2);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-text-secondary);
  transition: background-color var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-day-picker__day:hover {
  background-color: var(--color-bg-muted);
}

.fg-day-picker__day--selected {
  background-color: var(--color-primary);
  color: var(--color-primary-text);
}

.fg-day-picker__day--selected:hover {
  background-color: var(--color-primary-hover);
}

.fg-day-picker__day--today {
  border: 1px solid var(--color-text-secondary);
  color: var(--color-text-primary);
  font-weight: 500;
}

.fg-day-picker__dot {
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background-color: #f59e0b;
  box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.55);
  animation: fg-day-picker-dot-bounce 1.6s ease-in-out infinite;
}

@keyframes fg-day-picker-dot-bounce {
  0%, 100% {
    transform: translateY(0);
    box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.45);
  }
  35% {
    transform: translateY(-0.2rem);
    box-shadow: 0 0 0 0.35rem rgba(245, 158, 11, 0);
  }
  55% {
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .fg-day-picker__dot {
    animation: none;
  }
}

.fg-attendance-class {
  background-color: var(--color-bg-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  box-shadow: none;
  overflow: hidden;
  margin-bottom: var(--space-4);
}

.fg-attendance-class__header {
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-border);
  background-color: var(--color-bg-surface);
}

.fg-attendance-class__title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}

.fg-attendance-class__name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0;
  line-height: 1.3;
}

.fg-attendance-class__time {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-text-secondary, #6b7280);
  margin-top: 0.125rem;
  font-weight: 400;
}

.fg-attendance-class__stats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.fg-attendance-stat {
  display: inline-flex;
  align-items: baseline;
  gap: 0.25rem;
  padding: 0.25rem 0.625rem;
  border-radius: var(--radius-full, 9999px);
  font-size: 0.8125rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  line-height: 1.25;
}

.fg-attendance-stat__label {
  font-weight: 400;
  font-size: 0.75rem;
  opacity: 0.85;
}

.fg-attendance-stat--pending {
  background-color: #fffbeb;
  color: #b45309;
}

.fg-attendance-stat--confirmed {
  background-color: #f0fdf4;
  color: #15803d;
}

.fg-attendance-class__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}

.fg-attendance-class__badges {
  display: none;
}

/* Collapsible filter bar (backoffice lists) */
.fg-filter-bar__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}

.fg-filter-bar__form {
  display: none;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.fg-filter-bar__form--payments {
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .fg-filter-bar__form {
    display: grid;
  }

  .fg-filter-bar__form--payments {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

.fg-filter-bar--open .fg-filter-bar__form {
  display: grid;
}

.fg-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.25rem 0.625rem;
  border-radius: var(--radius-full, 9999px);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-muted, #f3f4f6);
  font-size: 0.8125rem;
  color: var(--color-text-secondary, #374151);
  cursor: pointer;
  max-width: 100%;
}

.fg-filter-chip:hover {
  background-color: var(--color-bg-surface);
  border-color: var(--color-primary, #b40000);
}

.fg-filter-chip__remove {
  font-size: 1rem;
  line-height: 1;
  opacity: 0.7;
}

.fg-filter-chips:empty {
  display: none;
}

.fg-attendance-roster-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.fg-attendance-roster-grid > .attendance-student-card,
.fg-attendance-roster-grid > .fg-attendance-roster-item {
  flex: 0 0 13rem;
  width: 13rem;
  max-width: 13rem;
}

@media (min-width: 1024px) {
  .fg-attendance-roster-grid {
    gap: var(--space-3);
  }
}

.fg-attendance-roster-item {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  grid-template-areas:
    "avatar name actions"
    "avatar badges actions";
  align-items: center;
  gap: 0 var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-surface);
  cursor: pointer;
  transition:
    border-color var(--duration-fast) ease,
    box-shadow var(--duration-fast) ease,
    transform var(--duration-fast) ease;
}

.fg-attendance-roster-item:hover {
  border-color: #d1d5db;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.fg-attendance-roster-item__avatar {
  grid-area: avatar;
  flex-shrink: 0;
}

.fg-attendance-roster-item__photo,
.fg-attendance-roster-item__initial {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

.fg-attendance-roster-item__initial {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #f3f4f6;
  color: #6b7280;
  font-size: 0.875rem;
  font-weight: 600;
}

.fg-attendance-roster-item__name {
  grid-area: name;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text-primary);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  align-self: end;
}

.fg-attendance-roster-item__meta {
  display: none;
}

.fg-attendance-roster-item__badges {
  grid-area: badges;
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  align-self: start;
  min-height: 0;
}

.fg-attendance-roster-item__badges:empty {
  display: none;
}

.fg-attendance-roster-item__actions {
  grid-area: actions;
  display: flex;
  flex-shrink: 0;
  gap: var(--space-1);
  align-self: center;
}

.fg-attendance-roster-item__remove {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: none;
  border-radius: 9999px;
  background: #fef2f2;
  color: #dc2626;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease;
}

.fg-attendance-roster-item__remove svg {
  width: 0.875rem;
  height: 0.875rem;
}

.fg-attendance-roster-item__remove:hover {
  background: #fee2e2;
}

.fg-attendance-roster-item__remove:active {
  transform: scale(0.94);
}

.fg-attendance-chip {
  display: inline-block;
  padding: 0.0625rem 0.375rem;
  border-radius: var(--radius-full, 9999px);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.4;
}

.fg-attendance-chip--success {
  background-color: #ecfdf5;
  color: #047857;
}

.fg-attendance-chip--danger {
  background-color: #fef2f2;
  color: #b91c1c;
}

@media (min-width: 1024px) {
  .fg-attendance-roster-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-3) var(--space-2) var(--space-2);
    min-height: 100%;
  }

  .fg-attendance-roster-item__avatar {
    margin-bottom: var(--space-2);
  }

  .fg-attendance-roster-item__photo,
  .fg-attendance-roster-item__initial {
    width: 3.5rem;
    height: 3.5rem;
    font-size: 1.125rem;
  }

  .fg-attendance-roster-item__name {
    width: 100%;
    font-size: 0.75rem;
    line-height: 1.3;
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    align-self: auto;
    margin-bottom: var(--space-1);
  }

  .fg-attendance-roster-item__meta {
    display: none;
  }

  .fg-attendance-roster-item__badges {
    justify-content: center;
    margin-bottom: var(--space-2);
    min-height: 1rem;
  }

  .fg-attendance-roster-item__actions {
    margin-top: auto;
    width: 100%;
    justify-content: center;
    padding-top: var(--space-2);
    border-top: 1px solid #f3f4f6;
  }
}

.fg-attendance-card--confirmed .fg-attendance-roster-item__photo,
.fg-attendance-card--confirmed .fg-attendance-roster-item__initial {
  box-shadow: 0 0 0 2px #fff, 0 0 0 3px #86efac;
}

.fg-attendance-card--pending .fg-attendance-roster-item__photo,
.fg-attendance-card--pending .fg-attendance-roster-item__initial {
  box-shadow: 0 0 0 2px #fff, 0 0 0 3px #fcd34d;
}

.fg-attendance-card--denied {
  opacity: 0.72;
}

.fg-attendance-card--denied .fg-attendance-roster-item__photo,
.fg-attendance-card--denied .fg-attendance-roster-item__initial {
  box-shadow: 0 0 0 2px #fff, 0 0 0 3px #d1d5db;
  filter: grayscale(0.35);
}

.fg-attendance-card--confirmed {
  border-color: #d1fae5;
  background-color: #fafdfa;
}

.fg-attendance-card--denied {
  border-color: #e5e7eb;
  background-color: #fafafa;
}

.fg-attendance-card--pending {
  border-color: #e5e7eb;
  background-color: var(--color-bg-surface);
}

/* Asistencia hub — day class cards */
.fg-attendance-day-cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: flex-start;
  max-width: none;
}

.fg-attendance-hub-card {
  display: block;
  width: 100%;
  max-width: 40rem;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  border-left-width: 4px;
  border-left-color: var(--schedule-accent, var(--color-primary));
  background: linear-gradient(
    135deg,
    var(--schedule-accent-bg, var(--color-primary-muted-bg)) 0%,
    var(--color-bg-surface) 58%
  );
  text-decoration: none;
  color: inherit;
  transition: box-shadow var(--duration-fast) ease, transform var(--duration-fast) ease;
}

.fg-attendance-hub-card:hover {
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.fg-attendance-hub-card--featured {
  max-width: min(48rem, 100%);
  font-size: 1.2em;
  animation: fg-attendance-featured-glow 3.5s ease-in-out infinite;
}

@keyframes fg-attendance-featured-glow {
  0%,
  100% {
    box-shadow:
      0 0 0 0 rgba(99, 102, 241, 0),
      var(--shadow-sm, 0 1px 2px rgba(15, 23, 42, 0.06));
  }

  50% {
    box-shadow:
      0 0 0 1px rgba(99, 102, 241, 0.22),
      0 0 22px 2px rgba(99, 102, 241, 0.18),
      var(--shadow-sm, 0 1px 2px rgba(15, 23, 42, 0.06));
  }
}

@media (prefers-reduced-motion: reduce) {
  .fg-attendance-hub-card--featured {
    animation: none;
    box-shadow:
      0 0 0 1px rgba(99, 102, 241, 0.18),
      var(--shadow-sm, 0 1px 2px rgba(15, 23, 42, 0.06));
  }
}

.fg-attendance-hub-card__head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.fg-attendance-hub-card__type {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--schedule-accent, var(--color-primary));
}

.fg-attendance-hub-card__time {
  font-size: var(--font-size-caption);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--color-text-secondary);
}

.fg-attendance-hub-card__name {
  margin: 0 0 var(--space-3);
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-text-primary);
}

.fg-attendance-hub-card__metrics {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: 0;
  padding: 0;
  list-style: none;
}

.fg-attendance-hub-card__metric {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  min-width: 5.5rem;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.85);
}

.fg-attendance-hub-card__metric-value {
  font-size: 1rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--color-text-primary);
  line-height: 1;
}

.fg-attendance-hub-card__metric-label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: lowercase;
}

.fg-attendance-hub-card__metric--pending .fg-attendance-hub-card__metric-value {
  color: #b45309;
}

.fg-attendance-hub-card__metric--confirmed .fg-attendance-hub-card__metric-value {
  color: #2563eb;
}

.fg-attendance-hub-card__metric--grad .fg-attendance-hub-card__metric-value {
  color: #059669;
}

.fg-attendance-hub-card__metric--payment .fg-attendance-hub-card__metric-value {
  color: #dc2626;
}

/* Class detail page */
.fg-attendance-detail__header {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  border-left-width: 4px;
  border-left-color: var(--schedule-accent, var(--color-primary));
  background: linear-gradient(
    135deg,
    var(--schedule-accent-bg, var(--color-primary-muted-bg)) 0%,
    var(--color-bg-surface) 68%
  );
  box-shadow: var(--shadow-sm);
}

.fg-attendance-detail__nav-row {
  display: grid;
  grid-template-columns: minmax(7rem, 1fr) minmax(0, 2fr) minmax(7rem, 1fr);
  align-items: start;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.fg-attendance-detail__nav-side {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.fg-attendance-detail__nav-side--end {
  justify-content: flex-end;
}

.fg-attendance-detail__nav-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: rgba(255, 255, 255, 0.8);
  color: var(--color-text-primary);
  font-size: var(--font-size-caption);
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
}

.fg-attendance-detail__nav-btn:hover {
  border-color: var(--schedule-accent, var(--color-primary));
  color: var(--schedule-accent, var(--color-primary));
}

.fg-attendance-detail__nav-btn--disabled {
  opacity: 0.45;
  pointer-events: none;
}

.fg-attendance-detail__cross-day-inline {
  font-size: 0.6875rem;
  font-weight: 600;
  color: #b45309;
  white-space: nowrap;
}

.fg-attendance-detail__hero {
  text-align: center;
  min-width: 0;
}

.fg-attendance-detail__name {
  margin: 0 0 var(--space-2);
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text-primary);
}

.fg-attendance-detail__chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
}

.fg-attendance-detail__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.625rem;
  border-radius: 999px;
  font-size: 0.8125rem;
  font-weight: 600;
  border: 1px solid transparent;
}

.fg-attendance-detail__chip-icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

.fg-attendance-detail__chip--date {
  background: rgba(255, 255, 255, 0.85);
  border-color: var(--color-border);
  color: var(--color-text-primary);
}

.fg-attendance-detail__chip--time {
  background: color-mix(in srgb, var(--schedule-accent, var(--color-primary)) 12%, white);
  color: var(--schedule-accent, var(--color-primary));
}

.fg-attendance-detail__chip--type {
  background: color-mix(in srgb, var(--schedule-accent, var(--color-primary)) 18%, white);
  color: var(--schedule-accent, var(--color-primary));
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: 0.6875rem;
}

.fg-attendance-detail__metrics-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid color-mix(in srgb, var(--schedule-accent, var(--color-border)) 22%, var(--color-border));
}

.fg-attendance-detail__stat-cards {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.fg-attendance-detail__stat-card {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 7.5rem;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: rgba(255, 255, 255, 0.82);
}

.fg-attendance-detail__stat-card--pending {
  border-color: #fde68a;
  background: linear-gradient(135deg, #fffbeb 0%, rgba(255, 255, 255, 0.9) 100%);
}

.fg-attendance-detail__stat-card--pending .fg-attendance-detail__stat-icon {
  color: #d97706;
}

.fg-attendance-detail__stat-card--confirmed {
  border-color: #bbf7d0;
  background: linear-gradient(135deg, #f0fdf4 0%, rgba(255, 255, 255, 0.9) 100%);
}

.fg-attendance-detail__stat-card--confirmed .fg-attendance-detail__stat-icon {
  color: #059669;
}

.fg-attendance-detail__stat-icon {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
}

.fg-attendance-detail__stat-value {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  color: var(--color-text-primary);
}

.fg-attendance-detail__stat-label {
  margin: 0.125rem 0 0;
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: lowercase;
}

.fg-attendance-detail__bulk-btn {
  margin-left: auto;
}

.fg-attendance-detail__stat-card--payment {
  border-color: #fecaca;
  background: linear-gradient(135deg, #fef2f2 0%, rgba(255, 255, 255, 0.9) 100%);
}

.fg-attendance-detail__stat-card--payment .fg-attendance-detail__stat-value {
  color: #b91c1c;
}

.fg-attendance-detail__stat-card--grad {
  border-color: #bbf7d0;
  background: linear-gradient(135deg, #ecfdf5 0%, rgba(255, 255, 255, 0.9) 100%);
}

.fg-attendance-detail__stat-card--grad .fg-attendance-detail__stat-value {
  color: #059669;
}

.fg-attendance-roster-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(14rem, 16.5rem);
  gap: var(--space-3);
  align-items: start;
}

.fg-attendance-roster-layout__cards {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: flex-start;
  min-width: 0;
}

.fg-attendance-roster-layout__cards > .attendance-student-card,
.fg-attendance-roster-layout__cards > .fg-attendance-roster-item {
  flex: 0 0 13rem;
  width: 13rem;
  max-width: 13rem;
}

.fg-attendance-roster-layout .fg-attendance-add-card {
  grid-column: 2;
  grid-row: 1;
  align-self: start;
  position: sticky;
  top: var(--space-3);
  height: fit-content;
  max-height: none;
}

.fg-attendance-section__empty--inline {
  flex: 1 1 100%;
  margin: 0;
}

.fg-attendance-add-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px dashed var(--color-primary-muted-border);
  background: linear-gradient(
    160deg,
    var(--color-primary-muted-bg) 0%,
    var(--color-bg-surface) 72%
  );
  box-sizing: border-box;
}

.fg-attendance-add-card__title {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text-primary);
}

.fg-attendance-add-card__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.fg-attendance-add-card__field {
  margin-bottom: 0;
}

.fg-attendance-add-card__submit {
  width: 100%;
}

.fg-attendance-detail__roster--large .fg-attendance-roster-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.fg-attendance-detail__roster--large .fg-attendance-roster-item__badges {
  justify-content: center;
  width: 100%;
  margin-bottom: var(--space-2);
}

.fg-attendance-detail__roster--large .fg-attendance-roster-item__actions {
  justify-content: center;
  width: 100%;
  margin-top: auto;
}

.fg-attendance-detail__roster--large .fg-attendance-roster-item__photo,
.fg-attendance-detail__roster--large .fg-attendance-roster-item__initial {
  width: 4.75rem;
  height: 4.75rem;
}

.fg-attendance-detail__roster--large .fg-attendance-roster-item__initial {
  font-size: 1.375rem;
}

.fg-attendance-detail__roster--large .fg-attendance-roster-item__name {
  font-size: 1rem;
}

.fg-attendance-detail__roster--large .fg-attendance-roster-item__meta {
  display: none;
}

.fg-attendance-detail__roster--large .fg-attendance-roster-grid {
  gap: var(--space-3);
}

@media (max-width: 767px) {
  .fg-attendance-detail__nav-row {
    grid-template-columns: 1fr;
  }

  .fg-attendance-detail__nav-side,
  .fg-attendance-detail__nav-side--end {
    justify-content: center;
  }

  .fg-attendance-detail__bulk-btn {
    margin-left: 0;
    width: 100%;
  }

  .fg-attendance-roster-layout {
    grid-template-columns: 1fr;
  }

  .fg-attendance-roster-layout .fg-attendance-add-card {
    grid-column: 1;
    grid-row: auto;
    order: -1;
    position: static;
  }
}

@media (min-width: 1280px) {
  .fg-attendance-hub-card {
    max-width: 44rem;
  }

  .fg-attendance-hub-card--featured {
    max-width: min(52.8rem, 100%);
  }

  .fg-attendance-detail__roster--large .fg-attendance-roster-item__photo,
  .fg-attendance-detail__roster--large .fg-attendance-roster-item__initial {
    width: 5.25rem;
    height: 5.25rem;
  }
}

.fg-attendance-action {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition:
    background-color var(--duration-fast) ease,
    border-color var(--duration-fast) ease,
    color var(--duration-fast) ease,
    transform var(--duration-fast) ease;
}

.fg-attendance-action:active {
  transform: scale(0.94);
}

.fg-attendance-action--confirm {
  color: #15803d;
  background-color: #f0fdf4;
  border-color: #bbf7d0;
}

.fg-attendance-action--confirm:hover {
  background-color: #15803d;
  border-color: #15803d;
  color: #fff;
}

.fg-attendance-action--deny {
  color: #9ca3af;
  background-color: transparent;
  border-color: #e5e7eb;
}

.fg-attendance-action--deny:hover {
  color: #dc2626;
  background-color: #fef2f2;
  border-color: #fecaca;
}

@media (min-width: 1024px) {
  .fg-attendance-action {
    width: 2rem;
    height: 2rem;
    font-size: 0.875rem;
  }
}

.fg-attendance-action:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.fg-attendance-grad-summary {
  font-size: 0.875rem;
  color: var(--color-text-secondary, #6b7280);
  margin: 0;
}

.fg-attendance-grad-summary__count {
  font-weight: 600;
  color: #15803d;
}

.fg-attendance-grad-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

@media (min-width: 768px) {
  .fg-attendance-grad-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 1280px) {
  .fg-attendance-grad-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

.fg-attendance-grad-grid__empty {
  grid-column: 1 / -1;
}

.fg-attendance-grad-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-3) var(--space-2);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-surface);
  text-decoration: none;
  color: inherit;
  min-height: 100%;
  transition:
    border-color var(--duration-fast) ease,
    box-shadow var(--duration-fast) ease,
    transform var(--duration-fast) ease;
}

.fg-attendance-grad-card:hover {
  border-color: #d1d5db;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  transform: translateY(-1px);
}

.fg-attendance-grad-card--eligible {
  border-color: #bbf7d0;
  background-color: #fafdfa;
}

.fg-attendance-grad-card__avatar {
  margin-bottom: var(--space-2);
}

.fg-attendance-grad-card__photo,
.fg-attendance-grad-card__initial {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

.fg-attendance-grad-card__initial {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #f3f4f6;
  color: #6b7280;
  font-size: 1.125rem;
  font-weight: 600;
}

.fg-attendance-grad-card--eligible .fg-attendance-grad-card__photo,
.fg-attendance-grad-card--eligible .fg-attendance-grad-card__initial {
  box-shadow: 0 0 0 2px #fff, 0 0 0 3px #86efac;
}

.fg-attendance-grad-card__name {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--space-1);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  width: 100%;
}

.fg-attendance-grad-card__belt {
  margin: 0 0 var(--space-1);
}

.fg-attendance-grad-card__message {
  font-size: 0.6875rem;
  color: var(--color-text-secondary, #6b7280);
  margin: 0;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.fg-attendance-grad-card__footer {
  margin-top: auto;
  padding-top: var(--space-2);
  width: 100%;
}

.fg-attendance-chip--belt {
  background-color: #eff6ff;
  color: #1d4ed8;
}

.fg-attendance-chip--muted {
  background-color: #f3f4f6;
  color: #6b7280;
}

/* --- Backoffice shell (v2) --- */
.fg-shell {
  min-height: 100vh;
  background-color: var(--color-bg-page);
  font-family: var(--font-sans);
}

.fg-shell__header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  height: var(--shell-header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: 0 var(--space-4);
  background-color: var(--shell-header-bg);
  border-bottom: 1px solid var(--shell-header-border);
  box-shadow: var(--shadow-sm);
}

.fg-shell__header-start,
.fg-shell__header-end {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}

.fg-shell__header-center {
  flex: 1;
  display: flex;
  justify-content: center;
  min-width: 0;
}

.fg-shell__brand {
  font-size: var(--font-size-label);
  font-weight: 600;
  color: var(--color-text-secondary);
  letter-spacing: -0.01em;
  white-space: nowrap;
}

.fg-shell__brand-mark {
  color: var(--color-primary);
}

.fg-shell__school-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  max-width: min(100%, 20rem);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  background-color: var(--color-info-bg);
  border: 1px solid var(--shell-sidebar-active-border);
  color: var(--color-info-text);
  font-size: var(--font-size-label);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fg-shell__user {
  display: none;
  font-size: var(--font-size-caption);
  color: var(--color-text-secondary);
}

@media (min-width: 640px) {
  .fg-shell__user {
    display: inline;
  }
}

.fg-shell__icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: var(--touch-target-min);
  min-height: var(--touch-target-min);
  padding: var(--space-2);
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background-color var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-shell__icon-btn:hover {
  background-color: var(--color-bg-muted);
  color: var(--color-text-primary);
}

.fg-shell__icon-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.fg-shell__sidebar {
  position: fixed;
  top: var(--shell-header-height);
  left: 0;
  bottom: 0;
  z-index: 40;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  overflow-y: auto;
  background-color: var(--shell-sidebar-bg);
  border-right: 1px solid var(--shell-sidebar-border);
  transition: width var(--duration-normal) ease, transform var(--duration-normal) ease;
  width: var(--shell-sidebar-width-expanded);
}

.fg-shell__sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-3);
}

.fg-shell__sidebar-nav--footer {
  margin-top: auto;
  border-top: 1px solid var(--shell-sidebar-border);
}

.fg-shell__link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-height: var(--touch-target-min);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  color: var(--shell-sidebar-text);
  text-decoration: none;
  font-size: var(--font-size-label);
  font-weight: 500;
  transition: background-color var(--duration-fast) ease, color var(--duration-fast) ease;
  white-space: nowrap;
}

.fg-shell__link:hover {
  background-color: var(--color-bg-muted);
  color: var(--shell-sidebar-text-hover);
}

.fg-shell__link--active {
  background-color: var(--shell-sidebar-active-bg);
  color: var(--shell-sidebar-active-text);
  box-shadow: inset 3px 0 0 var(--color-primary);
}

.fg-shell__link-icon {
  flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
}

.fg-shell__link-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fg-shell__link--config {
  width: 100%;
}

.fg-shell__link--config-expanded {
  background-color: color-mix(in srgb, var(--color-primary) 6%, var(--color-bg-muted));
  color: var(--shell-sidebar-text-hover);
  box-shadow: none;
}

.fg-shell__link--config-expanded:hover {
  background-color: color-mix(in srgb, var(--color-primary) 10%, var(--color-bg-muted));
}

.fg-shell__config-group {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.fg-shell__config-chevron {
  flex: 0 0 1rem;
  width: 1rem;
  height: 1rem;
  max-width: 1rem;
  max-height: 1rem;
  margin-left: auto;
  opacity: 0.55;
}

.fg-shell__config-chevron--animate {
  transition: transform var(--duration-normal) cubic-bezier(0.4, 0, 0.2, 1), opacity var(--duration-fast) ease;
}

.fg-shell__link--config[data-config-expanded] .fg-shell__config-chevron {
  transform: rotate(90deg);
}

.fg-shell__link--config-expanded .fg-shell__config-chevron,
.fg-shell__link--config.fg-shell__link--active .fg-shell__config-chevron {
  opacity: 0.85;
}

.fg-shell__config-chevron--open {
  transform: rotate(90deg);
}

.fg-shell__subnav-wrapper {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
}

.fg-shell__subnav-wrapper[data-initial-open] {
  grid-template-rows: 1fr;
  opacity: 1;
}

.fg-shell__subnav-wrapper--animate {
  transition:
    grid-template-rows var(--duration-normal) cubic-bezier(0.4, 0, 0.2, 1),
    opacity var(--duration-normal) ease;
}

.fg-shell__subnav-wrapper--open {
  grid-template-rows: 1fr;
  opacity: 1;
}

.fg-shell__subnav-inner {
  overflow: hidden;
  min-height: 0;
}

.fg-shell__subnav {
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin: var(--space-1) 0 var(--space-2);
  margin-left: calc(var(--space-3) + 0.5rem);
  padding: var(--space-1) 0 var(--space-1) var(--space-3);
  border-left: 2px solid color-mix(in srgb, var(--color-primary) 22%, var(--shell-sidebar-border));
}

.fg-shell__sublink {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 2.25rem;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  color: color-mix(in srgb, var(--shell-sidebar-text) 88%, transparent);
  text-decoration: none;
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.35;
  transition:
    background-color var(--duration-fast) ease,
    color var(--duration-fast) ease,
    box-shadow var(--duration-fast) ease;
}

.fg-shell__sublink-icon {
  flex: 0 0 0.9375rem;
  width: 0.9375rem;
  height: 0.9375rem;
  max-width: 0.9375rem;
  max-height: 0.9375rem;
  opacity: 0.7;
  transition: opacity var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-shell__sublink-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fg-shell__sublink:hover {
  background-color: color-mix(in srgb, var(--color-primary) 5%, var(--color-bg-muted));
  color: var(--shell-sidebar-text-hover);
}

.fg-shell__sublink:hover .fg-shell__sublink-icon {
  opacity: 0.9;
}

.fg-shell__sublink--active {
  background-color: color-mix(in srgb, var(--color-primary) 10%, var(--shell-sidebar-active-bg));
  color: var(--shell-sidebar-active-text);
  font-weight: 500;
  box-shadow: inset 2px 0 0 var(--color-primary);
}

.fg-shell__sublink--active .fg-shell__sublink-icon {
  opacity: 1;
  color: var(--color-primary);
}

.fg-shell--sidebar-collapsed .fg-shell__subnav-wrapper,
.fg-shell--sidebar-collapsed .fg-shell__config-chevron {
  display: none;
}

.fg-shell__overlay {
  position: fixed;
  inset: 0;
  top: var(--shell-header-height);
  z-index: 30;
  background-color: var(--overlay-bg);
}

.fg-shell__main {
  margin-top: var(--shell-header-height);
  min-height: calc(100vh - var(--shell-header-height));
  padding: var(--space-4);
  transition: margin-left var(--duration-normal) ease;
}

@media (min-width: 640px) {
  .fg-shell__main {
    padding: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .fg-shell__main {
    margin-left: var(--shell-sidebar-width-collapsed);
  }

  .fg-shell:not(.fg-shell--sidebar-collapsed) .fg-shell__main {
    margin-left: var(--shell-sidebar-width-expanded);
  }

  .fg-shell--sidebar-collapsed .fg-shell__sidebar {
    width: var(--shell-sidebar-width-collapsed);
  }

  .fg-shell--sidebar-collapsed .fg-shell__link {
    justify-content: center;
    padding-left: var(--space-2);
    padding-right: var(--space-2);
  }

  .fg-shell--sidebar-collapsed .fg-shell__link-label {
    display: none;
  }

  .fg-shell:not(.fg-shell--sidebar-collapsed) .fg-shell__sidebar {
    width: var(--shell-sidebar-width-expanded);
  }
}

@media (max-width: 1023px) {
  .fg-shell__sidebar {
    transform: translateX(-100%);
  }

  .fg-shell--mobile-open .fg-shell__sidebar {
    transform: translateX(0);
  }
}

.fg-shell__mobile-toggle {
  display: inline-flex;
}

.fg-shell__desktop-toggle {
  display: none;
}

@media (min-width: 1024px) {
  .fg-shell__mobile-toggle {
    display: none;
  }

  .fg-shell__desktop-toggle {
    display: inline-flex;
  }
}

/* Toast (fg-alert variant) */
.fg-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  pointer-events: auto;
  box-shadow: var(--shadow-md);
  animation: fg-toast-in var(--duration-normal) ease-out;
}

.fg-toast__message {
  flex: 1;
}

.fg-toast__close {
  flex-shrink: 0;
  border: none;
  background: transparent;
  color: inherit;
  opacity: 0.6;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}

.fg-toast__close:hover {
  opacity: 1;
}

.fg-toast--out {
  animation: fg-toast-out var(--duration-normal) ease-in forwards;
}

@keyframes fg-toast-in {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes fg-toast-out {
  from {
    transform: translateX(0);
    opacity: 1;
  }
  to {
    transform: translateX(100%);
    opacity: 0;
  }
}

#toast-container {
  position: fixed;
  top: calc(var(--shell-header-height) + var(--space-4));
  right: var(--space-4);
  left: var(--space-4);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  max-width: 28rem;
  margin-left: auto;
  pointer-events: none;
}

@media (min-width: 640px) {
  #toast-container {
    left: auto;
    width: 100%;
  }
}

.fg-auth-layout {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background-color: var(--color-bg-page);
}

/* --- Backoffice wizard (create student) --- */
.fg-stepper {
  margin-bottom: var(--space-6);
}

.fg-stepper__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.fg-stepper__item {
  flex: 1 1 auto;
  min-width: 0;
}

.fg-stepper__step {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  min-height: var(--touch-target-min);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-surface);
  color: var(--color-text-secondary);
  font-family: var(--font-sans);
  font-size: var(--font-size-caption);
  font-weight: 500;
  cursor: pointer;
  transition: border-color var(--duration-fast) ease, background-color var(--duration-fast) ease, color var(--duration-fast) ease;
}

.fg-stepper__step:disabled {
  cursor: default;
  opacity: 0.55;
}

.fg-stepper__step--active {
  border-color: var(--color-primary);
  background: var(--color-info-bg);
  color: var(--color-info-text);
}

.fg-stepper__step--done:not(:disabled) {
  border-color: var(--shell-sidebar-active-border);
  color: var(--color-text-primary);
}

.fg-stepper__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: var(--radius-full);
  background: var(--color-bg-muted);
  font-size: var(--font-size-caption);
  font-weight: 600;
  flex-shrink: 0;
}

.fg-stepper__step--active .fg-stepper__number {
  background: var(--color-primary);
  color: var(--color-primary-text);
}

.fg-stepper__step--done .fg-stepper__number {
  background: var(--color-success-bg);
  color: var(--color-success-text);
}

.fg-stepper__label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 639px) {
  .fg-stepper__label {
    display: none;
  }

  .fg-stepper__step {
    justify-content: center;
    padding: var(--space-2);
  }

  .fg-stepper--labels-only .fg-stepper__label {
    display: block;
    font-size: var(--font-size-caption);
  }

  .fg-stepper--labels-only .fg-stepper__step {
    justify-content: center;
    padding: var(--space-2) var(--space-3);
  }
}

.fg-stepper--labels-only .fg-stepper__step {
  justify-content: center;
}

.fg-wizard-footer--edit {
  position: sticky;
  bottom: 0;
  z-index: 20;
  flex-shrink: 0;
  margin: var(--space-4) calc(-1 * var(--space-4)) calc(-1 * var(--space-4));
  padding: var(--space-4);
  background-color: var(--color-bg-surface);
  box-shadow: 0 -4px 16px rgba(15, 23, 42, 0.06);
}

.fg-wizard-footer--edit .fg-icon-btn--lg svg {
  width: 1.2rem;
  height: 1.2rem;
}

.fg-member-wizard {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.fg-wizard-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  margin-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}

.fg-wizard-footer__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-left: auto;
}

.fg-wizard-step {
  display: block;
}

.fg-review-panel__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 640px) {
  .fg-review-panel__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.fg-review-panel__card {
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-surface);
}

.fg-review-panel__title {
  margin: 0 0 var(--space-3);
  font-size: var(--font-size-label);
  font-weight: 600;
  color: var(--color-text-primary);
}

.fg-review-panel__list {
  margin: 0;
}

.fg-review-panel__list > div {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-1) 0;
  font-size: var(--font-size-body);
  border-bottom: 1px solid var(--color-bg-muted);
}

.fg-review-panel__list > div:last-child {
  border-bottom: none;
}

.fg-review-panel__list dt {
  color: var(--color-text-secondary);
  font-weight: 500;
}

.fg-review-panel__list dd {
  margin: 0;
  text-align: right;
  color: var(--color-text-primary);
}

.fg-modal--wizard-sheet .fg-modal__panel {
  max-width: 42rem;
}

@media (max-width: 767px) {
  .fg-modal--wizard-sheet {
    padding: 0;
  }

  .fg-modal--wizard-sheet .fg-modal__panel {
    max-width: none;
    min-height: 100vh;
    border-radius: 0;
    margin: 0;
  }
}

/* Stacked modals (e.g. payment detail over edit-member wizard) */
.fg-modal--stacked {
  z-index: 120;
}

#payment-modal.fg-modal {
  z-index: 130;
}

/* Member modal — payment history subtab */
.member-payment-history__head {
  grid-template-columns: 1.1fr 0.9fr 1fr 1fr;
  gap: var(--space-3);
  padding: 0 var(--space-3) var(--space-2);
  font-size: var(--font-size-caption);
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.member-payment-history__list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 18rem;
  overflow-y: auto;
}

.member-payment-history__row {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  background: var(--color-bg-surface);
  overflow: hidden;
  transition: border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;
}

.member-payment-history__row:hover {
  border-color: color-mix(in srgb, var(--color-primary) 20%, var(--color-border));
  box-shadow: var(--shadow-sm, 0 1px 2px rgb(0 0 0 / 0.04));
}

.member-payment-history__main {
  width: 100%;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr 1fr 1fr auto;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-3);
  border: none;
  background: transparent;
  text-align: left;
  cursor: pointer;
  min-width: 0;
  transition: background var(--duration-fast);
}

.member-payment-history__main:hover {
  background: var(--color-bg-muted);
}

.member-payment-history__period {
  font-weight: 600;
  color: var(--color-text-primary);
}

.member-payment-history__date,
.member-payment-history__amount {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.member-payment-history__late {
  display: block;
  font-size: var(--font-size-caption);
  color: var(--color-danger, #b91c1c);
}

.member-payment-history__chevron {
  color: var(--color-text-secondary);
  opacity: 0.55;
  display: inline-flex;
  align-items: center;
}

@media (max-width: 639px) {
  .member-payment-history__main {
    grid-template-columns: 1fr 1fr auto;
    grid-template-rows: auto auto;
  }

  .member-payment-history__status {
    grid-column: 1 / 2;
  }

  .member-payment-history__amount {
    grid-column: 2 / 3;
    text-align: right;
  }

  .member-payment-history__chevron {
    grid-row: 1 / 3;
    grid-column: 3;
    align-self: center;
  }
}

/* Custom orders desk — specs/custom-orders-desk */
.fg-custom-order-workflow .fg-stepper__step {
  cursor: default;
  pointer-events: none;
}

.fg-custom-order-row--stale {
  box-shadow: inset 3px 0 0 var(--color-warning);
}

.fg-collect-summary__rows {
  margin: 0;
}

.fg-collect-summary__row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-2) 0;
  font-size: var(--font-size-body);
}

.fg-collect-summary__row--total {
  font-weight: 700;
  font-size: var(--font-size-h2);
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-2);
  padding-top: var(--space-3);
}

.fg-collect-summary__row dt {
  margin: 0;
  font-weight: 500;
}

.fg-collect-summary__row dd {
  margin: 0;
}

.fg-field-hint {
  margin: var(--space-1) 0 0;
  font-size: var(--font-size-caption);
  color: var(--color-text-secondary);
}

.fg-store-tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  margin-left: var(--space-2);
  padding: 0 0.35rem;
  border-radius: var(--radius-full);
  background: var(--color-success-bg);
  color: var(--color-success-text);
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1;
}

.fg-store-tab-badge--warning {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
}
