/* My page — phase 2 step 2.1-A (IA v2 + entry-card visual) */

.my-page {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

/* —— Entry card variants (my page only) —— */

.card--entry-account {
  border-left: 3px solid var(--gold);
}

.card--entry-pricing {
  border-left: 3px solid var(--accent);
}

.card--entry-study {
  border-left: 3px solid var(--gold);
}

.my-head.card {
  margin-top: 0;
}

.my-head .card-heading {
  margin-bottom: 0.5rem;
}

.my-head .my-profile__summary .card-heading {
  margin-bottom: 0;
}

/* —— Collapsible account profile —— */

.my-profile__details {
  margin: 0;
}

.my-profile__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  cursor: pointer;
  list-style: none;
  margin: 0;
  padding: 0;
  user-select: none;
}

.my-profile__summary::-webkit-details-marker {
  display: none;
}

.my-profile__summary::marker {
  content: "";
}

.my-profile__chevron {
  flex-shrink: 0;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 2px solid var(--ink-3);
  border-bottom: 2px solid var(--ink-3);
  transform: rotate(-45deg);
  margin-top: -0.15rem;
  transition: transform 0.2s ease;
}

.my-profile__details[open] .my-profile__chevron {
  transform: rotate(45deg);
  margin-top: 0.1rem;
}

.my-profile__details[open] .my-profile__body {
  padding-top: 0.65rem;
}

.my-profile__details--alert[open] .my-profile__alert-wrap {
  padding-top: 0.65rem;
}

.my-profile__alert-wrap .my-loading,
.my-profile__alert-wrap .my-error {
  padding: 0.35rem 0 0.15rem;
}

.my-head__placeholder {
  margin: 0;
  font-size: 0.91rem;
  line-height: 1.85;
  color: var(--ink-2);
}

/* —— Tab switcher + hub panel —— */

.my-page__tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
  margin-top: 0;
}

/* Tab entry cards: same chrome as homepage .card--entry, slightly shorter */
.my-tab.card {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0.8rem 1.1rem 0.75rem;
  background: var(--paper-2);
  border-radius: var(--radius-card);
  border-top: 1px solid var(--paper-3);
  border-right: 1px solid var(--paper-3);
  border-bottom: 1px solid var(--paper-3);
  border-left-width: 3px;
  border-left-style: solid;
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: inherit;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
  appearance: none;
  -webkit-appearance: none;
}

.my-tab.card .card-heading {
  margin-bottom: 0.35rem;
  font-size: 1rem;
}

.card--entry-pricing.my-tab {
  border-left-color: var(--accent);
}

.card--entry-study.my-tab {
  border-left-color: var(--gold);
}

.my-tab.card:hover {
  border-top-color: rgba(139, 69, 19, 0.25);
  border-right-color: rgba(139, 69, 19, 0.25);
  border-bottom-color: rgba(139, 69, 19, 0.25);
}

.my-tab.my-tab--active {
  background: rgba(139, 69, 19, 0.06);
  border-top-color: rgba(139, 69, 19, 0.35);
  border-right-color: rgba(139, 69, 19, 0.35);
  border-bottom-color: rgba(139, 69, 19, 0.35);
  box-shadow: 0 2px 10px rgba(26, 20, 16, 0.06);
}

.my-tab.card--entry-pricing.my-tab--active {
  border-left-color: var(--accent);
}

.my-tab.card--entry-study.my-tab--active {
  border-left-color: var(--gold);
}

.my-tab p {
  margin-bottom: 0.45rem;
  font-size: 0.86rem;
  line-height: 1.65;
}

.my-tab .associate-link {
  display: inline-block;
  margin-top: 0;
  font-size: 0.86rem;
  pointer-events: none;
}

.my-hub-panel {
  padding: 1.15rem 1.35rem 1rem;
}

.my-hub-panel__pane[hidden] {
  display: none;
}

.my-plan-desc {
  margin: 0.55rem 0 0;
  font-size: 0.84rem;
  line-height: 1.65;
  color: var(--ink-2);
}

.my-pricing-footnote {
  margin: 1rem 0 0;
  font-size: 0.82rem;
  color: var(--ink-3);
  text-align: center;
}

.my-pricing-footnote a {
  color: var(--accent);
  text-decoration: none;
}

.my-pricing-footnote a:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.my-hub-panel .buy-btn {
  display: block;
  width: 100%;
  margin-top: 1rem;
  padding: 0.75rem;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-body);
  font-size: 0.88rem;
  border: 1px solid var(--ink);
  border-radius: var(--radius-sm);
  cursor: pointer;
  letter-spacing: 0.08em;
  text-align: center;
  transition: background 0.2s, border-color 0.2s;
}

.my-hub-panel .buy-btn:hover:not(:disabled),
.my-hub-panel .buy-btn:focus-visible:not(:disabled) {
  background: var(--accent);
  border-color: var(--accent);
}

.my-hub-panel .buy-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.my-hub-panel .pricing-status {
  margin: 0.85rem 0 0;
  padding: 0.65rem 0.85rem;
  border-radius: var(--radius-sm);
  font-size: 0.86rem;
  line-height: 1.55;
  text-align: left;
}

.my-hub-panel .pricing-status--info {
  background: rgba(139, 69, 19, 0.08);
  color: var(--ink-1);
}

.my-hub-panel .pricing-status--warn {
  background: rgba(180, 83, 9, 0.1);
  color: #92400e;
}

.my-hub-panel .pricing-status--error {
  background: rgba(185, 28, 28, 0.08);
  color: #991b1b;
}

/* —— Section blocks (settings etc.) —— */

.my-block {
  margin-top: var(--space-xs);
}

.my-block__label {
  margin: 0 0 0.55rem;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}

/* —— Study panel —— */

.my-study-panel {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.my-study-panel .my-study__subhead {
  margin: 0 0 0.45rem;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--ink);
  letter-spacing: 0.03em;
}

.my-study__body {
  padding: 0.65rem 0.85rem;
  background: var(--paper);
  border: 1px solid var(--paper-3);
  border-radius: var(--radius-sm);
}

.my-study__empty {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.75;
  color: var(--ink-3);
}

.my-study__divider {
  height: 1px;
  margin: 1rem 0;
  background: var(--paper-3);
  border: none;
}

.my-device-note {
  margin: 0.85rem 0 0;
  font-size: 0.78rem;
  color: var(--ink-3);
  line-height: 1.5;
}

/* —— Settings menu group —— */

.my-menu {
  display: flex;
  flex-direction: column;
  margin: 0;
  background: var(--paper-2);
  border: 1px solid var(--paper-3);
  border-radius: var(--radius-card);
  overflow: hidden;
}

.my-menu--settings {
  margin-top: 0;
}

.my-menu__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  padding: 0.85rem 1.15rem;
  margin: 0;
  border: none;
  border-bottom: 1px solid var(--paper-3);
  background: transparent;
  font: inherit;
  font-size: 0.93rem;
  color: var(--ink-1);
  text-decoration: none;
  text-align: left;
  cursor: pointer;
  box-sizing: border-box;
}

.my-menu__row:last-child {
  border-bottom: none;
}

button.my-menu__row:not(:disabled):hover {
  background: var(--paper);
}

.my-menu__row--static {
  cursor: default;
}

.my-menu__row--static:hover {
  background: transparent;
}

.my-menu__row--btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.my-menu__label {
  font-weight: 500;
}

.my-menu__hint {
  font-size: 0.8rem;
  color: var(--ink-3);
  flex-shrink: 0;
}

/* —— Logout + legal —— */

.my-logout {
  display: block;
  width: 100%;
  margin: var(--space-sm) 0 0;
  padding: 0.85rem 1.25rem;
  border: 1px solid var(--paper-3);
  border-radius: var(--radius-card);
  background: var(--paper);
  font: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink-1);
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.my-logout--primary {
  background: var(--btn-solid-bg);
  border-color: var(--btn-solid-bg);
  color: var(--btn-solid-fg);
}

.my-logout--primary:not(:disabled):hover {
  background: var(--btn-solid-hover);
  border-color: var(--btn-solid-hover);
}

.my-logout:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.my-legal {
  margin: var(--space-md) 0 0;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--paper-3);
  font-size: 0.82rem;
  line-height: 1.8;
  text-align: center;
  color: var(--ink-3);
}

.my-legal a {
  color: var(--accent);
  text-decoration: none;
}

.my-legal a:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* —— Profile / checkout (wired in 2.1-B) —— */

.my-profile__body {
  padding: 0.1rem 0 0;
  text-align: left;
}

.my-profile__body--guest {
  text-align: center;
}

.my-profile__body--guest .my-actions {
  margin-top: 0.75rem;
}

.my-profile__label {
  margin: 0 0 0.35rem;
  font-size: 0.85rem;
  color: var(--ink-3);
}

.my-profile__email-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.65rem;
  margin: 0 0 0.5rem;
  line-height: 1.5;
}

.my-profile__email-row .my-profile__email {
  margin: 0;
  font-size: 1.05rem;
  color: var(--ink-1);
}

.my-profile__email-row .my-profile__meta {
  margin: 0;
  font-size: 0.9rem;
  color: var(--ink-2);
}

.my-profile__uid-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin: 0 0 0.65rem;
  font-size: 0.88rem;
  line-height: 1.5;
}

.my-profile__uid-row .my-profile__label {
  margin: 0;
  flex: 0 0 auto;
}

.my-profile__uid {
  font-family: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, monospace;
  font-size: 0.82rem;
  word-break: break-all;
  color: var(--ink-1);
  background: var(--paper);
  padding: 0.15rem 0.35rem;
  border-radius: var(--radius-sm);
}

.my-profile__copy {
  flex: 0 0 auto;
  font: inherit;
  font-size: 0.82rem;
  color: var(--accent);
  background: none;
  border: 1px solid rgba(139, 69, 19, 0.35);
  border-radius: var(--radius-sm);
  padding: 0.2rem 0.55rem;
  cursor: pointer;
}

.my-profile__copy:hover {
  background: rgba(139, 69, 19, 0.06);
}

.my-profile__copy-feedback {
  flex: 0 0 100%;
  font-size: 0.8rem;
  color: #2d6a4f;
}

.my-profile__meta {
  margin: 0 0 0.75rem;
  font-size: 0.9rem;
  color: var(--ink-2);
}

.my-profile__lead {
  margin: 0 0 0.75rem;
  font-size: 1rem;
  color: var(--ink-2);
  line-height: 1.6;
}

.my-badge {
  font-weight: 500;
}

.my-badge--ok {
  color: #2d6a4f;
}

.my-badge--warn {
  color: #b45309;
}

.my-balance {
  margin: 0.35rem 0 0.4rem;
  font-size: 1.25rem;
  color: var(--ink-1);
}

.my-balance--muted {
  font-size: 0.9rem;
  color: var(--ink-3);
}

.my-footnote {
  margin: 0.35rem 0 0;
  font-size: 0.85rem;
  line-height: 1.55;
  color: var(--ink-3);
}

.my-actions {
  margin-top: 1rem;
}

.my-actions__sep {
  margin: 0 0.65rem;
  color: var(--ink-3);
}

.my-link-btn {
  background: none;
  border: none;
  cursor: pointer;
  font: inherit;
  color: var(--accent);
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.my-link-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.my-loading,
.my-error {
  text-align: center;
  padding: 1rem 0;
  color: var(--ink-3);
  margin: 0;
}

.my-error {
  color: var(--ink-2);
}

.my-checkout-pending {
  font-size: 0.9rem;
  color: var(--ink-2);
  margin: 0.75rem 0;
  padding: 0.75rem 1rem;
  background: var(--paper);
  border-radius: var(--radius-sm);
  text-align: left;
}

.my-checkout-ok {
  font-size: 0.9rem;
  color: #2d6a4f;
  margin: 0.75rem 0;
}

.my-checkout-hint {
  font-size: 0.85rem;
  color: var(--ink-3);
  margin: 0.75rem 0;
}

.my-alert {
  margin: 0 0 1rem;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-sm);
  text-align: left;
  font-size: 0.88rem;
  line-height: 1.55;
}

.my-alert--frozen {
  background: rgba(180, 83, 9, 0.1);
  border: 1px solid rgba(180, 83, 9, 0.35);
  color: var(--ink-1);
}

.my-alert--frozen strong {
  display: block;
  margin-bottom: 0.35rem;
  color: #92400e;
}

.my-alert--frozen a {
  color: var(--accent);
}

.my-record-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.my-record-row {
  display: grid;
  gap: 0.2rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid var(--paper-3);
  font-size: 0.88rem;
}

.my-record-row:last-child {
  border-bottom: none;
}

.my-record-row__tag {
  font-size: 0.72rem;
  color: var(--accent);
  font-weight: 500;
}

.my-record-row__title {
  color: var(--ink-1);
  font-weight: 500;
}

.my-record-row__detail,
.my-record-row__meta {
  color: var(--ink-3);
  font-size: 0.82rem;
}

@media (max-width: 520px) {
  .my-page__tabs {
    grid-template-columns: 1fr;
  }
}
