/* Subpáginas (FAQ, Contact, Terms, Settings, Goal, My Courses) */
.list-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  margin-bottom: 14px;
}
.list-item {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px;
  cursor: pointer;
  transition: background 0.12s;
  width: 100%;
  text-align: left;
}
.list-item:hover { background: var(--surface-2); }
.list-item + .list-item { border-top: 1px solid var(--border); }
.list-item .ic {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--primary-soft);
  color: var(--orange);
  display: grid; place-items: center; font-size: 18px;
  flex-shrink: 0;
}
.list-item .body { flex: 1; min-width: 0; }
.list-item .label { font-size: 14px; color: var(--ink); font-weight: 500; margin: 0; }
.list-item .value { font-size: 12px; color: var(--muted); margin-top: 3px; }
.list-item .chev { color: var(--orange); font-size: 20px; }

/* Banner CTA (Fale conosco) */
.support-banner {
  background: var(--gradient);
  border-radius: var(--radius-card);
  padding: 20px;
  color: #fff;
  margin-bottom: 16px;
  position: relative;
  box-shadow: 0 8px 24px rgba(230,59,30,0.3);
}
.support-banner h2 {
  font-family: var(--font-display); font-style: italic; font-weight: 800;
  font-size: 20px; margin: 0 0 6px; letter-spacing: -0.01em;
}
.support-banner p { margin: 0; font-size: 13px; line-height: 1.5; opacity: 0.95; }
.support-banner .ic-big {
  position: absolute; top: 16px; right: 16px;
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,0.18);
  display: grid; place-items: center;
  font-size: 24px;
}

.contact-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  padding: 16px 18px;
  margin-bottom: 12px;
  display: flex; align-items: center; gap: 14px;
}
.contact-card .ic {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--primary-soft);
  color: var(--orange);
  display: grid; place-items: center; font-size: 20px;
  flex-shrink: 0;
}
.contact-card .info { flex: 1; min-width: 0; }
.contact-card .info .lbl {
  font-size: 11px; color: var(--muted); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.contact-card .info .val {
  font-size: 13px; color: var(--ink); margin-top: 3px;
  word-break: break-all;
}

/* FAQ */
.faq-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  margin-bottom: 12px;
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: border-color 0.15s;
}
.faq-card.open { border-color: rgba(255,90,31,0.4); }
.faq-q {
  padding: 16px 18px;
  display: flex; align-items: center; gap: 12px;
  cursor: pointer; user-select: none;
  font-size: 14px; color: var(--ink); font-weight: 500;
  line-height: 1.4;
}
.faq-q .num {
  flex-shrink: 0;
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--primary-soft);
  color: var(--orange);
  display: grid; place-items: center;
  font-size: 12px; font-weight: 800;
  font-family: var(--font-display); font-style: italic;
}
.faq-q .text { flex: 1; }
.faq-q .chev { color: var(--orange); font-size: 22px; transition: transform 0.2s; }
.faq-card.open .faq-q .chev { transform: rotate(90deg); }
.faq-a {
  display: none;
  padding: 4px 18px 18px;
  border-top: 1px solid var(--border);
  color: var(--body);
  font-size: 14px;
  line-height: 1.6;
}
.faq-card.open .faq-a { display: block; }

/* Goal time options (radio cards) */
.radio-list { display: grid; gap: 10px; }
.radio-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px 18px;
  display: flex; align-items: center; gap: 12px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.radio-card:hover { background: var(--surface-2); }
.radio-card.selected {
  border-color: var(--orange);
  background: var(--primary-soft);
  box-shadow: 0 0 0 2px rgba(255,90,31,0.18);
}
.radio-card .label {
  flex: 1; font-size: 15px; color: var(--ink); font-weight: 500;
}
.radio-card .dot {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--surface-3);
  display: grid; place-items: center;
}
.radio-card.selected .dot {
  background: var(--gradient-90); border-color: transparent;
}
.radio-card.selected .dot::after {
  content: ''; width: 8px; height: 8px;
  background: #fff; border-radius: 50%;
}

/* Settings inputs */
.input-group { margin-bottom: 16px; }
.input-group label {
  display: block;
  font-size: 11px; color: var(--muted); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  margin-bottom: 6px;
}
.input-group input {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px 16px;
  font-family: inherit;
  font-size: 15px;
  color: var(--ink);
  outline: none;
  transition: border-color 0.15s;
}
.input-group input:focus { border-color: var(--orange); box-shadow: 0 0 0 3px rgba(255,90,31,0.18); }
.input-group input::placeholder { color: var(--muted); }

/* Saved-for-later empty state */
.empty-saved {
  text-align: center;
  padding: 64px 24px;
  color: var(--body);
}
.empty-saved .ic {
  width: 80px; height: 80px; border-radius: 50%;
  background: var(--primary-soft);
  display: grid; place-items: center;
  margin: 0 auto 18px;
  color: var(--orange);
  font-size: 36px;
}
.empty-saved h3 {
  font-family: var(--font-display); font-style: italic; font-weight: 800;
  font-size: 20px; color: var(--title); margin: 0 0 8px;
}
.empty-saved p { font-size: 14px; color: var(--body); margin: 0; }

/* Course banner card (Cursos feitos) */
.banner-course {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  overflow: hidden;
  margin-bottom: 14px;
  box-shadow: var(--shadow-card);
  transition: transform 0.15s, border-color 0.15s;
}
.banner-course:hover { transform: translateY(-2px); border-color: rgba(255,90,31,0.35); }
.banner-course .cover {
  width: 100%;
  aspect-ratio: 16 / 8;
  background-size: cover; background-position: center;
  position: relative;
}
.banner-course .cover::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.85), rgba(0,0,0,0.1) 60%, transparent);
}
.banner-course .badge {
  position: absolute;
  left: 14px; bottom: 12px;
  background: var(--gradient-90); color: #fff;
  padding: 5px 11px; border-radius: var(--radius-pill);
  font-size: 11px; font-weight: 800;
  font-family: var(--font-display); font-style: italic;
  letter-spacing: 0.02em; z-index: 1;
}
.banner-course .meta {
  padding: 14px 16px;
}
.banner-course .meta .t {
  font-family: var(--font-display); font-style: italic; font-weight: 700;
  font-size: 15px; color: var(--title); margin: 0 0 4px;
  line-height: 1.3; letter-spacing: -0.01em;
}
.banner-course .meta .d { font-size: 12px; color: var(--body); margin: 0; }
