.view {
  animation: page-in 260ms ease-out;
}

@keyframes page-in {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-panel,
.surface,
.card,
.answer-card,
.notice,
.choice-card,
.data-row {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgb(255 253 249 / 0.94);
  box-shadow: var(--shadow-sm);
}

.hero-panel {
  position: relative;
  display: grid;
  gap: var(--space-7);
  overflow: hidden;
  border-color: var(--line-strong);
  background:
    linear-gradient(135deg, rgb(255 255 255 / 0.76), transparent 46%),
    linear-gradient(145deg, var(--surface) 0%, #f7f0e6 100%);
  box-shadow: var(--shadow-md);
  padding: clamp(1.5rem, 4vw, 3rem);
}

.hero-kicker {
  margin-bottom: var(--space-3);
  color: var(--accent);
  font-size: var(--step--1);
  font-weight: 800;
  letter-spacing: 0.08em;
}

.hero-title {
  max-width: 14ch;
  margin-bottom: var(--space-4);
  font-size: var(--step-4);
  line-height: 1.22;
}

.hero-copy {
  max-width: 42rem;
  color: var(--muted);
  font-size: var(--step-1);
  line-height: 1.82;
}

.line-visual {
  display: grid;
  min-height: 12rem;
  align-items: end;
  border: 1px solid rgb(111 135 121 / 0.28);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 76% 22%, rgb(255 255 255 / 0.92) 0 8%, transparent 8.5%),
    linear-gradient(90deg, transparent 0 17%, rgb(111 135 121 / 0.24) 17.5% 18.2%, transparent 18.7% 49%, rgb(64 91 80 / 0.52) 49.3% 50.3%, transparent 50.8%),
    linear-gradient(180deg, transparent 0 68%, rgb(111 135 121 / 0.28) 69% 70%, transparent 71%),
    linear-gradient(145deg, #f2e9dc, #e8eee8);
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 0.72);
  padding: var(--space-6);
}

.line-visual::after {
  content: "";
  display: block;
  width: min(100%, 17rem);
  height: 5.4rem;
  border: 1px solid rgb(64 91 80 / 0.72);
  border-bottom: 0;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  background:
    linear-gradient(90deg, transparent 0 20%, rgb(168 96 73 / 0.72) 20% 22%, transparent 23% 66%, rgb(168 96 73 / 0.72) 66% 68%, transparent 69%),
    linear-gradient(180deg, transparent 0 61%, rgb(64 91 80 / 0.78) 62% 65%, transparent 66%);
  opacity: 0.82;
}

.stack {
  display: grid;
  gap: var(--space-4);
}

.stack-lg {
  display: grid;
  gap: clamp(1.5rem, 3vw, 2.25rem);
}

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.split {
  display: grid;
  gap: var(--space-5);
}

.section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-4);
  margin: var(--space-8) 0 var(--space-4);
}

.section-heading h2 {
  margin: 0;
  font-size: var(--step-3);
}

.eyebrow {
  color: var(--muted);
  font-size: var(--step--1);
}

.button,
.icon-button,
.text-button,
.chip,
.segmented button {
  min-height: 2.9rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--text);
  padding: 0.72rem 1rem;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease, transform 180ms ease, opacity 180ms ease;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-weight: 750;
  text-decoration: none;
}

.button svg,
.icon-button svg,
.text-button svg {
  transition: transform 180ms ease;
}

.button:hover svg,
.icon-button:hover svg,
.text-button:hover svg {
  transform: translate3d(0, -1px, 0);
}

.button.primary {
  border-color: var(--primary-dark);
  background: linear-gradient(180deg, #506d60, var(--primary-dark));
  box-shadow: 0 7px 18px rgb(64 91 80 / 0.2);
  color: var(--surface);
}

.button.accent {
  border-color: var(--accent);
  background: linear-gradient(180deg, #b96f54, var(--accent));
  box-shadow: 0 7px 18px rgb(168 96 73 / 0.18);
  color: #fffdf9;
}

.button.danger {
  border-color: var(--danger);
  background: var(--danger-soft);
  color: var(--danger);
}

.button.ghost,
.text-button {
  background: transparent;
}

.button:hover,
.icon-button:hover,
.text-button:hover,
.chip:hover,
.segmented button:hover {
  border-color: var(--primary);
  background: var(--primary-soft);
  box-shadow: var(--shadow-sm);
  color: var(--primary-dark);
  transform: translateY(-1px);
}

.button:active,
.icon-button:active,
.text-button:active,
.chip:active,
.segmented button:active {
  transform: translateY(0);
}

.icon-button {
  display: inline-grid;
  width: 2.75rem;
  padding: 0;
  place-items: center;
}

.choice-grid {
  display: grid;
  gap: var(--space-4);
}

.choice-card {
  position: relative;
  display: grid;
  width: 100%;
  min-height: 8.25rem;
  align-content: start;
  gap: var(--space-2);
  overflow: hidden;
  border-color: rgb(207 194 177 / 0.82);
  padding: var(--space-5);
  color: var(--text);
  text-align: left;
  transition: border-color 180ms ease, background 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.practice-choice-grid .choice-card {
  animation: choice-in 320ms ease-out backwards;
}

.choice-card::after {
  position: absolute;
  right: var(--space-5);
  bottom: 0;
  left: var(--space-5);
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  content: "";
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: center;
  transition: opacity 180ms ease, transform 220ms ease;
}

.choice-card strong {
  color: var(--primary-dark);
  font-family: var(--font-display);
  font-size: var(--step-1);
  line-height: 1.55;
}

.choice-card span {
  color: var(--muted);
  line-height: 1.65;
}

.choice-card[data-selected="true"],
.choice-card:hover {
  border-color: var(--primary);
  background: linear-gradient(145deg, #fffefb, #f6f1e8);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.choice-card[data-selected="true"]::after,
.choice-card:hover::after,
.choice-card:focus-visible::after {
  opacity: 0.9;
  transform: scaleX(1);
}

.choice-card:active {
  transform: translateY(0) scale(0.995);
}

.practice-choice-grid .choice-card:nth-child(2) {
  animation-delay: 45ms;
}

.practice-choice-grid .choice-card:nth-child(3) {
  animation-delay: 90ms;
}

.practice-choice-grid .choice-card:nth-child(4) {
  animation-delay: 135ms;
}

@keyframes choice-in {
  from {
    opacity: 0;
    transform: translate3d(0, 8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

.badge,
.tag {
  display: inline-flex;
  min-height: 1.75rem;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 700;
  padding: 0.15rem 0.58rem;
}

.badge.danger {
  border-color: var(--danger);
  background: var(--danger-soft);
  color: var(--danger);
}

.answer-card {
  display: grid;
  gap: var(--space-5);
  border-color: var(--line-strong);
  box-shadow: var(--shadow-md);
  padding: clamp(1.25rem, 3vw, 2rem);
}

.answer-text {
  margin: 0;
  color: var(--text);
  font-family: var(--font-display);
  font-size: var(--step-2);
  font-weight: 700;
  line-height: 1.72;
}

.answer-meta {
  color: var(--muted);
  font-size: var(--step--1);
}

.segmented {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
}

.segmented button[aria-pressed="true"] {
  border-color: var(--primary-dark);
  background: var(--primary-dark);
  color: var(--surface);
}

.notice {
  border-left: 4px solid var(--primary);
  background: linear-gradient(90deg, rgb(223 232 225 / 0.58), rgb(255 253 249 / 0.94) 32%);
  padding: var(--space-5);
  color: var(--muted);
}

.notice strong {
  color: var(--primary-dark);
}

.notice.danger {
  border-color: var(--danger);
  background: var(--danger-soft);
  color: var(--danger);
}

.field {
  display: grid;
  gap: var(--space-2);
}

.field label {
  color: var(--primary-dark);
  font-weight: 700;
}

.input,
.select,
.textarea {
  width: 100%;
  min-height: 3rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--surface-strong);
  box-shadow: inset 0 1px 2px rgb(41 46 43 / 0.04);
  color: var(--text);
  padding: 0.74rem 0.9rem;
}

.input:hover,
.select:hover,
.textarea:hover {
  border-color: var(--primary);
}

.textarea {
  min-height: 8rem;
  resize: vertical;
}

.bottom-bar {
  position: sticky;
  bottom: calc(var(--space-3) + var(--safe-bottom));
  z-index: 15;
  display: flex;
  gap: var(--space-2);
  justify-content: flex-end;
  margin-top: var(--space-6);
  border: 1px solid rgb(207 194 177 / 0.82);
  border-radius: var(--radius-md);
  background: rgb(255 253 249 / 0.9);
  box-shadow: var(--shadow-lg);
  padding: var(--space-2);
  backdrop-filter: blur(18px);
}

.toast {
  position: fixed;
  right: var(--space-4);
  bottom: calc(var(--space-4) + var(--safe-bottom));
  z-index: 60;
  max-width: min(22rem, calc(100vw - 2rem));
  border: 1px solid var(--primary);
  border-radius: var(--radius-md);
  background: rgb(255 253 249 / 0.96);
  box-shadow: var(--shadow-lg);
  color: var(--primary-dark);
  padding: var(--space-3) var(--space-4);
  backdrop-filter: blur(14px);
}

.data-row {
  display: grid;
  gap: var(--space-1);
  padding: var(--space-3);
}

.empty-state {
  display: grid;
  gap: var(--space-3);
  justify-items: start;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius-md);
  background: rgb(255 253 249 / 0.7);
  padding: var(--space-6);
}

.mini-graphic {
  width: 8rem;
  height: 5rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background:
    linear-gradient(90deg, transparent 0 30%, var(--primary) 31% 32%, transparent 33% 65%, var(--accent) 66% 67%, transparent 68%),
    linear-gradient(180deg, transparent 0 64%, var(--primary-soft) 65% 68%, transparent 69%),
    var(--surface-2);
}

@media (min-width: 640px) {
  .choice-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .segmented {
    display: flex;
    flex-wrap: wrap;
  }

  .split {
    grid-template-columns: minmax(0, 1.55fr) minmax(17rem, 0.75fr);
    align-items: start;
  }
}

@media (min-width: 900px) {
  .hero-panel {
    grid-template-columns: minmax(0, 1.25fr) minmax(19rem, 0.75fr);
    align-items: center;
  }
}

@media (max-width: 639px) {
  .section-heading {
    align-items: flex-start;
    flex-direction: column;
  }

  .choice-card {
    min-height: auto;
  }

  .cluster .button {
    flex: 1 1 12rem;
  }
}

@media (max-width: 639px) {
  .practice-choice-grid .choice-card {
    animation-duration: 220ms;
  }
}

@media (prefers-reduced-motion: reduce) {
  .view,
  .practice-choice-grid .choice-card {
    animation: none;
  }

  .button,
  .button svg,
  .icon-button,
  .icon-button svg,
  .text-button,
  .text-button svg,
  .chip,
  .segmented button,
  .choice-card,
  .choice-card::after,
  .meter-bar span {
    transition: none;
  }
}
