.prediction .title {
  font-size:21px;
  font-weight:bold;
  margin-bottom:12px;
}

.action {
  margin-bottom:30px;
  margin-left:20px;
  margin-right:20px;
  background-color: var(--paper);
  border-radius:8px;
  border:1px solid var(--gridline);
}

.action:last-of-type {
  margin-bottom:0;
}

.action .name {
  font-weight:bold;
  font-family: "Tobias", sans-serif;
  font-weight:350;
  font-size:20px;
  padding:20px 32px;
  background-color: var(--paper);
  border-bottom:1px solid var(--gridline);
  border-radius:7px 7px 0 0;
}

.action .action_description {
  padding:22px 32px;
  font-size:17px;
  text-wrap:pretty;
}

.article_headline {
  padding:42px 29px;
  border-bottom:1px solid var(--gridline);
  text-align:center;
}

.article_headline h1 {
  line-height:1.1;
  font-size:28px;
  margin-bottom:0;
  text-wrap: balance;
  font-family: "Ivar";
  font-weight:600;
  letter-spacing:-0.5px;
}

.article_headline h1::first-letter {
  text-transform: uppercase;
}

@media (min-width:900px) {
  .article_headline {
    padding:72px 52px;
  }

  .article_headline h1 {
    font-size:38px;
  }
}

.article_summary {
  padding:11px 23px;
  border-bottom:1px solid var(--gridline);
}

@media (min-width:900px) {
  .article_summary {
    padding:40px 52px;
  }
}

.article_summary span.summary {
  display:block;
  max-width:700px;
  position:relative;
  margin-left:auto;
  margin-right:auto;
  margin-bottom:40px;
  font-size:18px;
  font-family: "Ivar", sans-serif;
  text-wrap:pretty;
}

@media (min-width:900px) {
  .article_summary span.summary {
    font-size:21px;
  }
}

.article_summary span.summary.hidden {
  display: none;
}

.article_summary_inner {
  position:relative;
  margin-left:auto;
  margin-right:auto;
}

.article_source {
  padding:32px;
}

.summary_actions a {
  font-family:"Matter SemiMono", -apple-system, system-ui;
  text-decoration:none;
  border:1px solid #b2b2b2;
  padding:5px 7px;
  border-radius:8px;
  font-size:13px;
  color:#797878;
  display:inline-flex;
  align-items:center;
}

.summary_actions a:hover {
  color:#797878;
}

img.link_icon {
  height:auto;
  width:14px;
  position:relative;
  margin-right:3px;
}

.predictions {
  padding:21px 12px;
  border-radius:0 0 7px 7px;
}

@media (min-width: 900px) {
  .predictions {
    padding:43px;
  }
}

.predictions h2 {
  font-size:21px;
}

span.timeline_pill {
  padding:4px 8px;
  display:inline-block;
  margin-bottom:20px;
  font-size:13px;
  border:1px solid var(--gridline);
  border-radius:6px;
  background-color:var(--off-white);
}

.short_term_predictions {
  margin-bottom:60px;
}

.block {
  border-radius:14px;
  margin-bottom:20px;
  box-shadow: var(--box-shadow-combined);
  transition: transform 50ms, margin 50ms;
}

.block.generated {
  margin-bottom:35px;
}

.block .block_heading {
  font-family: "Ivar";
  padding: 20px 18px;
  background-color:var(--soft-black);
  color:var(--gentle-white);
  font-weight:400;
  font-size:18px;
  border-radius:14px 14px 0 0;
  text-wrap:nowrap;
}

@media (min-width:900px) {
  .block .block_heading {
    padding:20px 32px;
  }
}

.block .block_content {
  padding:32px;
  font-size:17px;
}

.block .block_prediction:nth-child(odd) {
  background-color:var(--gentle-grey);
}

.block .block_prediction:last-of-type {
  border-radius:0 0 13px 13px;
}

.block .block_prediction .title {
  font-size:20px;
  font-family: "Ivar";
  letter-spacing:-0.5px;
  font-weight:600;
  margin-bottom:4px;
  padding-left:18px;
  padding-right:18px;
  padding-top:26px;
  padding-bottom:5px;
  text-wrap: pretty;
}

.block_prediction .title::first-letter {
  text-transform: uppercase;
}

.block .block_prediction .title a, .block .block_prediction .description a {
  color:var(--soft-black);
  text-decoration:none;
}

.block .block_prediction .description {
  padding-left:18px;
  padding-right:18px;
  font-size:18px;
  text-wrap:pretty;
}

.demo .block .block_prediction .description {
  padding-bottom:26px;
}

@media (min-width:900px) {
  .block .block_prediction .title {
    padding-left:42px;
    padding-right:42px;
    padding-top:42px;
  }
  .block .block_prediction .description {
    padding-left:42px;
    padding-right:42px;
  }
  .demo .block .block_prediction .description {
    padding-bottom:42px;
  }
}

.block_learnings .block_prediction .description {
  padding-bottom:42px;
}

.block_prediction .no_data_angles {
  text-align:center;
  padding:40px 18px;
  font-family: "Matter SemiMono", monospace;
  font-size:15px;
  text-wrap:balance;
}

.block_prediction .actions {
  height:0px;
  opacity:0;
  transition: height 200ms, padding-top 200ms, opacity 200ms;
  overflow: clip;
}

.block_prediction .actions_wrapper {
  padding-bottom:32px;
}

.block_prediction .actions_wrapper.open .actions {
  height:auto;
  padding-top:26px;
  opacity:1;
}

.block_prediction .actions_wrapper img.actions_arrow {
  width:18px;
  height:auto;
  transition: transform 200ms;
}

.block_prediction .actions_wrapper.open img.actions_arrow {
  transform: rotate(90deg);
}

.block_prediction .actions_wrapper span.heading {
  cursor: pointer;
  padding-left:32px;
  padding-right:32px;
  display:flex;
  align-items: center;
  font-weight:bold;
}

.block_generating_message {
  font-size:17px;
  padding:32px;
  text-align:center;
}

.block_impact {
  min-height:155px;
}

.block_impact .block_content {
  height:0px;
  opacity:0;
  transition: height 200ms, padding-top 200ms, opacity 200ms;
  overflow: clip;
}

.block_impact.generated .block_content {
  height:auto;
  opacity:1;
  padding:32px;
}

.block_impact.generated .block_generating_message {
  display:none;
}

.generating .block_generating_message {
  display:block;
  animation: fade-out 0.2s ease-in-out forwards;
  animation-delay: 1.4s;
}

.block_impact.generating {
  border: 1px solid #0000;
  border-radius: 12px;
  background: linear-gradient(#fff, #fff) padding-box, linear-gradient(
        var(--angle),
        #f88f0e, #5267ff, #ff14dd, #ffb768, #8d9bff, #ff0ad5
      ) border-box;
  animation: generating 1.9s ease-in-out, rotate 1.9s linear infinite;
}

.block_impact.generated .block_content {
  animation: fade-in 0.2s ease-in-out;
}

@keyframes generating {
  0% {
    transform: scale(1);
  }
  60% {
    transform: scale(1);
  }
  80% {
    transform: scale(0.985);
  }
  90% {
    transform: scale(1.015);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes rotate {
  to {
    --angle: 360deg;
  }
}

@property --angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@keyframes wiggle {
  0%, 100% {
    transform: rotate(0deg);
  }
  20% {
    transform: rotate(-0.8deg);
  }
  40% {
    transform: rotate(0.8deg);
  }
  60% {
    transform: rotate(-0.4deg);
  }
  80% {
    transform: rotate(0.4deg);
  }
}

.wiggle {
  animation: wiggle 0.4s ease-in-out 3;
  animation-delay: 1s;
}

.block_impact.generated .block_heading, .block_answers.generated .block_heading {
  padding:20px 18px;
}

@media (min-width:900px) {
  .block_impact.generated .block_heading, .block_answers.generated .block_heading {
    padding:20px 42px;
  }
}

.block_impact {
  border-radius:6px;
  margin-bottom:40px;
  box-shadow: var(--box-shadow-combined);
  transition: transform 50ms;
}

.block_impact .block_heading {
  padding: 18px 32px;
  background-color:var(--soft-black);
  color:var(--gentle-white);
  font-family: "Tobias", sans-serif;
  font-weight:350;
  font-size:22px;
  border-radius:9px 9px 0 0;
}

.block_impact .block_content {
  font-size:17px;
}

.block_answers {
  transition: transform 600ms, margin 200ms; 
}

.block_answers .block_heading {
  background-color:#fdf5f5;
  color:#826c6d;
  border-radius:14px;
  cursor: pointer;
  transition: background-color 50ms, color 50ms;
  display:flex;
  align-items:center;
  border:1px solid #d3b6b8;
}

.block_answers.generated .block_heading, .block_answers.generating .block_heading {
  border:0;
}

.block_answers:hover {
  transition: transform 200ms;
  transform: scale(1.01);
}

.block_answers .block_prediction {
  height:0px;
  opacity:0;
  transition: height 200ms, padding-top 200ms, opacity 200ms, background-color 100ms;
  overflow: clip;
}

.block.generated .block_heading {
  font-family:"Ivar";
  font-weight:600;
  font-size:20px;
  background-color:var(--deep-rose);
  color:var(--gentle-white);
  border-radius:13px 13px 0 0;
}

.block_rationale .block_prediction .rationale {
  padding:18px;
  font-size:18px;
}

@media (min-width:900px) {
  .block_rationale .block_prediction .rationale {
    padding:32px;
  }
}

.block_market.generated .description {
  padding-top:30px;
}

.block_answers.generated .block_prediction {
  height:auto;
  opacity:1;
}

.block_answers .block_thinking {
  height:0px;
  opacity:0;
  transition: height 200ms, padding-top 200ms, opacity 200ms;
  overflow: clip;
  text-align:center;
}

.block_answers.generating .block_thinking {
  height:auto;
  opacity:1;
  padding:32px;
}

.block_answers.generating {
  transform:scale(1);
  border: 1px solid #0000;
  border-radius: 13px;
  background: linear-gradient(#fff, #fff) padding-box, linear-gradient(
        var(--angle),
        #f88f0e, #5267ff, #ff14dd, #ffb768, #8d9bff, #ff0ad5
      ) border-box;
  animation: rotate 1.9s linear infinite;
}

.block_answers.generating .block_heading {
  background-color:var(--paper);
}

.block_answers.generating .block_heading {
  border-radius:13px;
}

.block_answers span.thinking_status {
  opacity:0;
  transition: opacity 500ms;
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-family: "Matter SemiMono", monospace;
  font-size:16px;
}

svg.loading_spinner {
  width:19px;
  height:auto;
}

.generating svg.loading_spinner {
  animation: spinup 700ms linear forwards, spin 350ms linear 700ms infinite;
}

@keyframes spinup {
  0% {
    transform: rotate(0deg);
  }
  20% {
    transform: rotate(10deg);
  }
  40% {
    transform: rotate(40deg);
  }
  60% {
    transform: rotate(100deg);
  }
  80% {
    transform: rotate(200deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.block_answers.generating span.thinking_status svg.loading_spinner {
  stroke: var(--soft-grey);
}

.block_answers.generating span.thinking_status {
  opacity:1;
}

.block_answers.generated span.thinking_status {
  display:none;
}

.block_answers.generating span.heading {
  display:none;
}

.block_answers.generated:hover {
  transform: scale(1);
}

.block_answers.generating .block_heading, .block_answers.generated .block_heading {
  cursor: default;
}

.summary_actions {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px;
  margin-bottom:20px;
  justify-content: space-between;
  max-width:700px;
  position:relative;
  margin-left:auto;
  margin-right:auto;
}

.impact_score_rationale {
  background-color:var(--gentle-grey);
  border:1px solid var(--soft-grey);
  border-radius:8px;
  height:0px;
  opacity:0;
  transition: height 200ms, padding-top 200ms, padding-bottom 200ms, opacity 200ms;
  overflow: clip;
  padding-left:28px;
  padding-right:28px;
  position:relative;
  margin-left:12px;
  margin-right:12px;
}

@media (min-width:800px) {
  .impact_score_rationale {
    margin-left:43px;
    margin-right:43px;
  }
}

.impact_score_rationale.revealed {
  height: auto;
  opacity: 1;
  padding-top:28px;
  padding-bottom:28px;
  margin-bottom:28px;
}

.impact_score_heading {
  display:block;
  font-family: "Inter";
  font-weight:700;
  font-size:17px;
  margin-bottom:7px;
}

.article_summary_inner span.published_at {
  font-size:14px;
  font-family: "Matter SemiMono", -apple-system, sans-serif;
  display:block;
  margin-bottom:20px;
  color:var(--soft-grey);
  max-width:700px;
  margin-left:auto;
  margin-right:auto;
  position:relative;
}

.insight_type_bar {
  text-align:center;
}

span.insight_type {
  font-family:"Matter SemiMono", -apple-system, system-ui;
  display:inline-block;
  border:1px solid var(--gridline);
  background-color:var(--paper);
  color:#6b6969;
  border-radius:18px;
  font-size:12px;
  padding:6px 19px;
  position: relative;
  bottom:18px;
  box-shadow:0 0 4px -2px #7b777775;
}

span.insight_type a {
  text-decoration:none;
  color:#6b6969;
}

.load_more_wrapper {
  text-align:center;
  padding:24px;
  border-bottom:1px solid var(--gridline);
}

.nothing_this_week_wrapper {
  border-bottom:1px solid var(--gridline);
}

.nothing_this_week {
  text-align:center;
  border-radius:9px;
  padding:40px 30px;
  margin:32px;
}

@media (min-width:900px) {
  .nothing_this_week {
    padding:80px 30px;
  }
}

.nothing_this_week p {
  margin-bottom:0;
}

span.week_label {
  display:block;
  margin-bottom:10px;
  font-weight:600;
  border-bottom:1px solid var(--gridline);
  padding-bottom:16px;
  margin-bottom:20px;
}

.week_wrapper {
  padding:48px 12px;
  border-bottom:1px solid var(--gridline);
}

@media (min-width:900px) {
  .week_wrapper {
    padding:48px 32px;
  }
}

.week_wrapper:nth-child(odd) {
  background-color:var(--gentle-grey);
}

.week_wrapper:last-of-type {
  border-bottom:0;
}

.week {
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

a.insight_card_wrapper {
  width:100%;
  text-decoration: none;
  border-radius:8px;
  color: var(--soft-black);
  transition: width 150ms, transform 600ms;
  overflow:hidden;
}

a.insight_card_wrapper:hover {
  transform:scale(1.015);
  transition: transform 150ms;
}

@media (min-width:1000px) {
  a.insight_card_wrapper {
    width:32.4%;
    display:flex;
  }
}

a.insight_card_wrapper:hover {
  color: var(--soft-black);
}

.insight_card {
  border:1px solid var(--gridline);
  border-radius:8px;
  background-color:var(--paper);
}

@media (min-width:1000px) {
  .insight_card {
    display:flex;
  }
}

.insight_card .priority {
  font-family:"Matter SemiMono", -apple-system, sans-serif;
  padding:8px 12px;
  border-bottom:1px solid var(--gridline);
  border-radius:7px 7px 0 0;
  font-size:13px;
  background-color:var(--soft-black);
  color:var(--gentle-white);
}

.insight_card .priority.high {
  background-color:var(--brand-red);
  color:var(--gentle-white);
  border-bottom:1px solid var(--brand-red);
}

.insight_card .details {
  display:flex;
  flex-direction: column;
  position:relative;
}

.insight_card .details .card_title {
  font-weight: 600;
  font-size:17px;
  line-height:1.2;
  text-wrap: pretty;
  border-radius:7px 7px 0 0;
}

.insight_card .details .card_title::first-letter {
  text-transform:uppercase;
}

.insight_card .details .card_summary {
  color: var(--hard-grey);
  padding:14px;
  padding-top:0;
  font-size:15px;
  line-height:1.2;
  flex-grow:1;
}

.insight_card span.pr_campaign_score {
  display:block;
  margin-bottom:4px;
  font-weight:bold;
}

.insight_card .details .card_brands {
  padding:14px;
  padding-top:0;
  line-height:1;
  display:flex;
  flex-wrap:wrap;
  gap:4px;
}

.insight_card .details .card_brands span.card_brand {
  background-color:var(--forest);
  color:#fff;
  padding:4px 6px;
  font-size:12px;
  font-family:"Matter SemiMono", monospace;
  border-radius:4px;
}

.insight_card.approval_yes .details .card_brands span.card_brand {
  background-color:#fff;
  color:var(--forest);
}

.insight_card .card_brand_name {
  font-family: "Matter SemiMono";
  letter-spacing:-0.4px;
  color:var(--soft-grey);
  border-top:1px solid var(--gridline);
  font-size:13px;
  padding:3px 17px;
}

.insight_card .card_publisher_details {
  font-family: "Matter SemiMono";
  letter-spacing:-0.4px;
  color:var(--soft-grey);
  background-color:#fafafa;
  border-top:1px solid var(--gridline);
  font-size:13px;
  padding:9px 17px;
  border-radius:0 0 7px 7px;
  white-space:nowrap;
  overflow:hidden;
  display:flex;
  align-items:center;
  gap:5px;
}

.insight_card svg.flag {
  width:16px;
  height:auto;
  border-radius:50%;
}

.none_found {
  padding:40px;
  text-align:center;
}

.insight_card img.favicon, .insight_card img.news_icon {
  background-color:var(--paper);
  width:28px;
  height:auto;
  border:1px solid var(--gridline);
  border-radius:7px;
  padding:3px;
}

.insight_card svg.alert_icon {
  width:25px;
  height:auto;
  padding:5px;
  stroke: #fff;
  margin-left:0;
}

.insight_card svg.policy_icon {
  width:25px;
  height:auto;
  padding:5px;
  stroke: var(--hard-grey);
  margin-left:0;
}

.insight_card img.news_icon {
  width:16px;
  padding:6px;
}

.insight_card .heading_wrapper {
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap:12px;
  padding-left:14px;
  padding-right:14px;
  padding-bottom:8px;
  padding-top:16px;
}

.insight_card.approval_no {
  opacity:0.6;
}

.insight_card.approval_yes {
  background-color:var(--forest);
  color:#fff;
}

.insight_card.approval_yes .details .card_summary {
  color:#fff;
}

.insight_card.approval_yes .card_publisher_details {
  background-color:#0c755b;
  border-top:1px solid #076a52;
  color:#ffffffbf;
}

.article_summary_inner .sources {
  font-family: "Matter SemiMono", -apple-system, sans-serif;
  color:var(--soft-grey);
  max-width:700px;
  margin-left:auto;
  margin-right:auto;
  position:relative;
}

.article_summary_inner .sources:hover img.source_favicon {
  margin-right:-7px;
  transition: margin 150ms 150ms;
}

.article_summary_inner .brands {
  font-family: "Matter SemiMono", monospace;
  max-width:700px;
  margin-left:auto;
  margin-right:auto;
  position:relative;
  margin-bottom:20px;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}

.article_summary_inner .brands span.brand {
  font-size:14px;
  background-color:var(--forest);
  border-radius:4px;
  padding:4px 4px;
  color:#fff;
}

.insight_card.policy {
  background-color:var(--soft-black);
  color:var(--paper);
}

.insight_card.policy svg.policy_badge {
  width:19px;
  height:auto;
  position:relative;
  top:3px;
}

.insight_card.policy .details .card_summary {
  color:#a3a3a3;
}

.insight_card.policy .card_publisher_details {
  background-color:#252424;
  color:#a3a3a3;
  border-top:1px solid #202020;
}

.insight_card.high_priority {
  background-color:var(--alert-red);
  color:#fff;
  box-shadow:0 0 11px -6px var(--alert-red);
}

.insight_card.high_priority .details .card_summary {
  color:#fff;
  opacity:0.75;
}

.insight_card.high_priority .card_publisher_details {
  background-color:#de3943;
  border-top:1px solid #d83641;
  color:#f2bdc0;
}

.insight_card.palette_1 .card_publisher_details {
  background-color:#FFFDE7;
  border-top:1px solid var(--gridline);
  color:#938686;
}

.insight_card.palette_2 .card_publisher_details {
  background-color:var(--soft-black);
  border-top:1px solid var(--soft-black);
  color:#fff;
}

.insight_card.palette_3 .card_publisher_details {
  background-color:#3333FF;
  border-top:1px solid #3333FF;
  color:#fff;
}

.insight_card.palette_4 .card_publisher_details {
  background-color:#FF9966;
  border-top:1px solid #FF9966;
  color:#fff;
}

.insight_card.palette_5 .card_publisher_details {
  background-color:#CE7182;
  border-top:1px solid #CE7182;
  color:#fff;
}

.insight_card.palette_6 .card_publisher_details {
  background-color:#0A005A;
  border-top:1px solid #0A005A;
  color:#fff;
}

.insight_card.palette_7 .card_publisher_details {
  background-color:#055A5B;
  border-top:1px solid #055A5B;
  color:#fff;
}

.insight_card.palette_8 .card_publisher_details {
  background-color:#ffd54a;
  border-top:1px solid #ffd54a;
  color:#88732c;
}

.insight_card.palette_9 .card_publisher_details {
  background-color:#167C80;
  border-top:1px solid #167C80;
  color:#fff;
}

.insight_card.palette_10 .card_publisher_details {
  background-color:#FF8B8B;
  border-top:1px solid #FF8B8B;
  color:#fff;
}

.insight_card.palette_11 .card_publisher_details {
  background-color:#005397;
  border-top:1px solid #005397;
  color:#fff;
}

.insight_card.palette_12 .card_publisher_details {
  background-color:#E31E23;
  border-top:1px solid #E31E23;
  color:#fff;
}

.insight_card.palette_13 .card_publisher_details {
  background-color:#0035AD;
  border-top:1px solid #0035AD;
  color:#fff;
}

.sources span {
  display:block;
  margin-bottom:6px;
  font-size:14px;
}

img.source_favicon {
  width:27px;
  height:27px;
  border-radius:40px;
  padding:4px;
  border:1px solid var(--gridline);
  background-color:var(--paper);
  margin-right:-17px;
  transition:margin 250ms, transform 125ms;
}

.sources a.source_link:hover img.source_favicon {
  transition: transform 150ms;
  transform: scale(1.25);
}

.summary_actions .left {
  display:flex;
  align-items:center;
  gap:6px;
}


.fade {
  transition: opacity 1.4s ease, visibility 1.4s ease;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  height:0px;
  transition: height 1200ms, opacity 1200ms;
  overflow: clip;
  
}

.fade.visible {
  height:auto;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.meta_bar_wrapper {
  border-bottom:1px solid var(--gridline);
}

.meta_bar {
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding:20px 12px;
  gap:7px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.meta_bar::-webkit-scrollbar {
  display:none;
}

@media (min-width:900px) {
  .meta_bar {
    padding:20px 43px;
  }
}

.meta_bar .right {
  display:flex;
  gap:6px;
  position: relative;
}

.meta_bar .impact_button {
  box-shadow:0 0 4px -2px #7b777775;
  border-radius:16px;
  padding:7px 11px;
  font-size:14px;
  border:1px solid var(--gridline);
  font-family: "Matter SemiMono", -apple-system, system-ui;
  text-decoration:none;
  display:inline-flex;
  gap:4px;
  align-items:center;
  color:#777070;
  white-space:nowrap;
  cursor:default;
}

.meta_bar .impact_button svg.alert_icon {
  width:18px;
  height:auto;
  margin-right:4px;
  stroke: #fb436d;
}

.meta_bar .impact_button.high_impact {
  color:#fb436d;
  border:1px solid #fb436d;
}

.bookmark_button, .forward_button, .calendar_button {
  margin-bottom:0;
  line-height:inherit;
  display:flex;
  border:1px solid var(--soft-grey);
  border-radius:50%;
  padding:8px;
  width:36px;
  height:36px;
}

.bookmark_button .bookmark_icon, .forward_button .forward_icon, .calendar_button .calendar_icon {
  position: relative;
  width: 18px;
  height: auto;
  stroke: var(--soft-grey);
  fill: none;
  transition: fill 0.15s ease, stroke 0.15s ease, transform 0.15s ease;
}

.bookmark_button {
  border:1px solid var(--deep-rose);
}

.bookmark_button .bookmark_icon {
  stroke: var(--deep-rose);
}

.forward_button .forward_icon {
  stroke:var(--soft-grey);
}

.bookmark_button .bookmark_icon:active, .forward_button .forward_icon:active, .calendar_button .calendar_icon:active {
  transform:scale(0.95);
}

.bookmark_button.bookmarked {
  background-color:var(--deep-rose);
  border:1px solid var(--deep-rose);
}

.bookmark_button.bookmarked .bookmark_icon {
  stroke:var(--paper);
}

.bookmark_button.bookmarked, .bookmark_button.bookmarked:hover {
  color:var(--forest);
}

[data-controller~="forward-button"] {
  position:relative;
}

.copy_tooltip {
  position:absolute;
  bottom:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  background:var(--soft-grey);
  color:#fff;
  font-size:11px;
  font-family:"Matter SemiMono", monospace;
  white-space:nowrap;
  padding:4px 8px;
  border-radius:4px;
  pointer-events:none;
  opacity:0;
  transition:opacity 150ms ease;
  z-index:20;
}

.copy_tooltip::after {
  content:'';
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  border:4px solid transparent;
  border-top-color:var(--soft-grey);
}

.copy_tooltip--visible {
  opacity:1;
}

.rationale p {
  margin-bottom:0;
  text-wrap:pretty;
}

.demo .rationale p {
  margin-bottom:0;
  text-wrap:pretty;
}

.rationale .hidden {
  display:none;
}

.generating_predictions_message {
  background-color:var(--gentle-grey);
  border:1px solid var(--gridline);
  border-radius:9px;
  padding:20px 18px;
  margin-bottom:20px;
  font-family:"Matter SemiMono", monospace;
  font-size:15px;
  text-wrap:pretty;
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--hard-grey);
}

@media (min-width:900px) {
  .generating_predictions_message {
    padding:20px 32px;
  }
}

.generating_predictions_message svg {
  stroke: var(--hard-grey);
}

.expert_comment_description {
  padding-bottom:20px;
}

.expert_comment_example {
  background-color:var(--subtle-white);
  border-top:1px solid var(--subtle-border);
  padding:20px 0;
  font-size:15px !important;
  font-family: "Matter SemiMono", monospace;
  border-left:7px solid var(--deep-rose);
}

.expert_comment .description:first-of-type {
  padding-top:32px;
  padding-bottom:32px;
}

span.disclaimer {
  display:block;
  margin-bottom:8px;
  opacity:0.7;
}

span.inline-bold {
  font-weight:600;
}

.data_idea_description {
  padding-bottom:10px;
}

.data_idea_description:last-of-type {
  padding-bottom:42px;
}

.save_idea_wrapper {
  padding-left:18px;
  padding-right:18px;
  padding-top:12px;
  padding-bottom:29px;
}

@media(min-width: 900px) {
  .save_idea_wrapper {
    padding-left:42px;
    padding-right:42px;
  }
}

button.save_idea_button {
  display:flex;
  align-items: center;
  gap:6px;
  font-family: "Inter", sans-serif;
  font-weight:600;
  font-size:13px;
  line-height:34px;
  padding:0 12px;
  border:1px solid var(--gridline);
  border-radius:25px;
  margin-bottom:0;
  transition: transform 100ms;
  background-color:var(--deep-rose);
  color:var(--paper);
  border:1px solid #d18083;
}

button.save_idea_button:hover {
  border:1px solid var(--gridline);
  color:var(--paper);
  border:1px solid #d18083;
}

button.save_idea_button:active, button.save_idea_button:focus {
  color:var(--paper);
  border:1px solid #d18083;
}

button.save_idea_button:active {
  transform:scale(0.98);
}

button.save_idea_button svg {
  width:16px;
  height:auto;
}