/* ============================================================
   Consent (participant privacy preferences) page.
   Structure in @layer layout, paint in @layer design. Content-named
   classes only — no legacy/appearance names, no hardcoded color.
   Reuses .app-screen from elements.css. See docs/FRONTEND-ARCHITECTURE.md.
   ============================================================ */

@layer layout {
  .consent__intro { display: grid; gap: var(--mea-space-1); }
  .consent__content { display: grid; gap: var(--mea-space-6); }

  /* Consent list: one card per data-use, stacked. */
  .consent-list { display: grid; gap: var(--mea-space-3); margin: 0; padding: 0; list-style: none; }

  .consent-item { display: grid; gap: var(--mea-space-3);
                  padding: var(--mea-space-4); border-radius: var(--mea-radius-xl); }
  .consent-item__header { display: grid; grid-template-columns: 1fr auto;
                          gap: var(--mea-space-4); align-items: start; }
  .consent-item__heading { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .consent-item__title, .consent-item__desc { margin: 0; }

  .consent-item__status { display: flex; flex-wrap: wrap; align-items: center;
                          justify-content: space-between; gap: var(--mea-space-2); }
  .consent-item__changed { margin: 0; }
  .consent-learn-more { display: inline-flex; align-items: center; gap: var(--mea-space-1);
                        min-height: var(--t-target-min, 44px);
                        padding: var(--mea-space-1) var(--mea-space-2);
                        border: 0; background: transparent; cursor: pointer; }

  .consent-card-error { margin: 0; }
  .consent-card-error[hidden] { display: none; }

  .consent-learn-content { padding: var(--mea-space-3);
                           border-radius: var(--mea-radius-md); }

  /* Toggle switch: a labelled checkbox styled as a sliding control. */
  .consent-toggle { position: relative; display: inline-flex; flex-shrink: 0;
                    inline-size: 3.25rem; block-size: 1.75rem; }
  .consent-toggle__input { position: absolute; inset: 0; margin: 0; opacity: 0; cursor: pointer; }
  .consent-toggle__input:disabled { cursor: default; }
  .consent-toggle__slider { position: absolute; inset: 0; border-radius: var(--mea-radius-pill);
                            transition: background var(--mea-dur-fast); pointer-events: none; }
  .consent-toggle__slider::before { content: ""; position: absolute;
                                    inset-block-start: 0.1875rem; inset-inline-start: 0.1875rem;
                                    inline-size: 1.375rem; block-size: 1.375rem;
                                    border-radius: var(--mea-radius-circle);
                                    transition: transform var(--mea-dur-fast); }
  .consent-toggle__input:checked + .consent-toggle__slider::before { transform: translateX(1.5rem); }

  /* Your Rights: explanatory copy plus a list of data-rights actions. */
  .consent-rights { display: grid; gap: var(--mea-space-4);
                    padding: var(--mea-space-5); border-radius: var(--mea-radius-2xl); }
  .consent-rights__title, .consent-rights__body { margin: 0; }
  .consent-rights__list { display: grid; gap: var(--mea-space-3); margin: 0; padding: 0; list-style: none; }

  .consent-right { margin: 0; }
  .consent-right__action,
  .consent-right--toggle { display: grid; grid-template-columns: auto 1fr auto;
                           gap: var(--mea-space-3); align-items: center;
                           padding: var(--mea-space-3); border-radius: var(--mea-radius-lg); }
  .consent-right__action { text-decoration: none; }
  .consent-right__icon { display: inline-flex; align-items: center; justify-content: center;
                         inline-size: 2.5rem; block-size: 2.5rem; border-radius: var(--mea-radius-circle);
                         font-size: var(--mea-text-lg); }
  .consent-right__text { display: grid; gap: var(--mea-space-1); min-inline-size: 0; }
  .consent-right__label, .consent-right__hint { margin: 0; }
  .consent-right__chevron { font-size: var(--mea-text-lg); }

  /* Global Privacy Control footnote. */
  .consent-gpc { display: flex; align-items: center; gap: var(--mea-space-2);
                 padding: var(--mea-space-3) var(--mea-space-4); border-radius: var(--mea-radius-lg); }
  .consent-gpc__text { margin: 0; }
}

@layer design {
  .consent__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-2xl);
                    font-weight: var(--mea-w-bold); color: var(--t-text); }
  .consent__subtitle { font-size: var(--mea-text-md); color: var(--t-text-secondary); }

  .consent-item { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                  box-shadow: var(--mea-shadow-sm); }
  .consent-item__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-md);
                         font-weight: var(--mea-w-bold); color: var(--t-text); }
  .consent-item__desc { font-size: var(--mea-text-sm); color: var(--t-text-secondary);
                        line-height: var(--mea-lh-snug); }
  .consent-item__changed { font-size: var(--mea-text-xs); color: var(--t-text-muted); }

  .consent-learn-more { color: var(--t-link); font-size: var(--mea-text-sm);
                        font-weight: var(--mea-w-semibold);
                        transition: color var(--mea-dur-fast); }
  .consent-learn-more:hover { color: var(--t-link-hover); }

  .consent-card-error { font-size: var(--mea-text-sm); color: var(--t-error-text); }

  .consent-learn-content { background: var(--t-bg-recessed); color: var(--t-text-secondary);
                           font-size: var(--mea-text-sm); line-height: var(--mea-lh-relaxed); }

  .consent-toggle__slider { background: var(--t-bg-active); }
  .consent-toggle__slider::before { background: var(--t-card-bg); box-shadow: var(--mea-shadow-sm); }
  .consent-toggle__input:checked + .consent-toggle__slider { background: var(--t-success); }
  .consent-toggle__input:focus-visible + .consent-toggle__slider { outline: 2px solid var(--t-border-focus);
                                                                   outline-offset: 2px; }

  .consent-rights { background: var(--t-card-bg); border: 1px solid var(--t-card-border);
                    box-shadow: var(--mea-shadow-sm); }
  .consent-rights__title { font-family: var(--mea-font-citizen); font-size: var(--mea-text-lg);
                           font-weight: var(--mea-w-bold); color: var(--t-text); }
  .consent-rights__body { font-size: var(--mea-text-md); color: var(--t-text-secondary);
                          line-height: var(--mea-lh-normal); }

  .consent-right__action,
  .consent-right--toggle { background: var(--t-bg-recessed); }
  .consent-right__action { transition: background var(--mea-dur-fast); }
  .consent-right__action:hover { background: var(--t-bg-active); }
  .consent-right__icon--request { background: var(--t-success); color: var(--t-accent-text); }
  .consent-right__icon--delete { background: var(--t-error); color: var(--t-accent-text); }
  .consent-right__icon--ccpa { background: var(--t-accent); color: var(--t-accent-text); }
  .consent-right__label { font-size: var(--mea-text-base); font-weight: var(--mea-w-semibold); color: var(--t-text); }
  .consent-right__hint { font-size: var(--mea-text-sm); color: var(--t-text-muted); }
  .consent-right__chevron { color: var(--t-text-muted); }

  .consent-gpc { background: var(--t-bg-recessed); }
  .consent-gpc__mark { color: var(--t-text-muted); }
  .consent-gpc--on .consent-gpc__mark { color: var(--t-success); }
  .consent-gpc__text { font-size: var(--mea-text-sm); color: var(--t-text-secondary); }
}
