/* FINAL SIGNAL RUN — aligned, shorter titles, matched colors */

.nc-signal-row {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  align-items: stretch;
  padding: 20px 4px 34px;
}

.nc-signal-card {
  flex: 0 0 150px;
  min-height: 520px;
  max-height: 520px;
  padding: 18px 16px;
  display: grid;
  grid-template-rows: 42px 150px 140px 76px 40px;
  align-items: start;
  border-radius: 16px;
}

.nc-signal-title {
  min-height: 150px;
  max-height: 150px;
  font-size: 15px;
  line-height: 1.32;
  font-weight: 850;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 6;
  -webkit-box-orient: vertical;
}

.nc-rank {
  background: var(--dial-color);
  box-shadow: 0 0 18px color-mix(in srgb, var(--dial-color) 70%, transparent);
}

.nc-mini-dial {
  justify-self: center;
  align-self: center;
  width: 112px;
  height: 112px;
  margin: 0 auto;
  background:
    radial-gradient(circle at center, #071427 53%, transparent 54%),
    conic-gradient(from 225deg,
      var(--dial-color) calc(var(--score) * 1%),
      rgba(255, 255, 255, .08) 0);
  animation:
    dialPop .75s ease both,
    dialPulse 2.8s ease-in-out infinite;
}

.nc-mini-dial::before {
  background:
    conic-gradient(from 225deg,
      var(--dial-color) calc(var(--score) * 1%),
      rgba(255, 255, 255, .08) 0);
  animation: dialSweep 1.2s ease both;
}

.nc-mini-dial strong {
  font-size: 27px;
  text-shadow: 0 0 14px var(--dial-color);
}

.nc-mini-dial small {
  font-size: 10px;
}

.nc-signal-card p {
  text-align: center;
  color: #aab8d8;
  font-size: 13px;
  line-height: 1.5;
  margin: 0;
}

.nc-card-link {
  color: var(--dial-color);
  font-weight: 850;
  margin-top: auto;
}

.nc-signal-card:nth-child(1) {
  --dial-color: #19f2d0;
}

.nc-signal-card:nth-child(2) {
  --dial-color: #2d7dff;
}

.nc-signal-card:nth-child(3) {
  --dial-color: #6867ff;
}

.nc-signal-card:nth-child(4) {
  --dial-color: #9a5cff;
}

.nc-signal-card:nth-child(5) {
  --dial-color: #ec45c7;
}

.nc-signal-card:nth-child(6) {
  --dial-color: #ff5f72;
}

.nc-signal-card:nth-child(7) {
  --dial-color: #ff8a16;
}

.nc-signal-card:nth-child(8) {
  --dial-color: #ffd51f;
}

.nc-signal-card:nth-child(9) {
  --dial-color: #60e95d;
}

.nc-signal-card:nth-child(10) {
  --dial-color: #20e0dc;
}

.nc-signal-card:nth-child(1) .nc-mini-dial {
  animation-delay: .02s;
}

.nc-signal-card:nth-child(2) .nc-mini-dial {
  animation-delay: .08s;
}

.nc-signal-card:nth-child(3) .nc-mini-dial {
  animation-delay: .14s;
}

.nc-signal-card:nth-child(4) .nc-mini-dial {
  animation-delay: .20s;
}

.nc-signal-card:nth-child(5) .nc-mini-dial {
  animation-delay: .26s;
}

.nc-signal-card:nth-child(6) .nc-mini-dial {
  animation-delay: .32s;
}

.nc-signal-card:nth-child(7) .nc-mini-dial {
  animation-delay: .38s;
}

.nc-signal-card:nth-child(8) .nc-mini-dial {
  animation-delay: .44s;
}

.nc-signal-card:nth-child(9) .nc-mini-dial {
  animation-delay: .50s;
}

.nc-signal-card:nth-child(10) .nc-mini-dial {
  animation-delay: .56s;
}

@keyframes dialSweep {
  0% {
    clip-path: circle(0% at 50% 50%);
    transform: rotate(-150deg) scale(.78);
    opacity: 0;
  }

  100% {
    clip-path: circle(80% at 50% 50%);
    transform: rotate(0deg) scale(1);
    opacity: 1;
  }
}

@keyframes dialPop {
  0% {
    transform: scale(.78);
    opacity: 0;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes dialPulse {

  0%,
  100% {
    filter: drop-shadow(0 0 8px color-mix(in srgb, var(--dial-color) 40%, transparent));
  }

  50% {
    filter: drop-shadow(0 0 22px color-mix(in srgb, var(--dial-color) 80%, transparent));
  }
}

/* EXACT SIGNAL CARD LAYOUT — bottom mockup */

.nc-signal-row {
  display: flex;
  gap: 22px;
  overflow-x: auto;
  align-items: stretch;
  padding: 24px 6px 38px;
}

.nc-signal-card {
  flex: 0 0 172px;
  height: 640px;
  padding: 30px 20px 24px;
  display: grid;
  grid-template-rows: 58px 255px 160px 78px 42px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(13, 28, 55, .96), rgba(5, 12, 25, .98));
  border: 1px solid rgba(88, 140, 255, .24);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05), 0 22px 60px rgba(0, 0, 0, .38);
}

.nc-rank {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  background: var(--dial-color);
  box-shadow: 0 0 18px color-mix(in srgb, var(--dial-color) 70%, transparent);
}

.nc-signal-title {
  color: #fff;
  font-size: 18px;
  font-weight: 900;
  line-height: 1.42;
  min-height: 255px;
  max-height: 255px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 10;
  -webkit-box-orient: vertical;
  text-decoration: none;
}

.nc-mini-dial {
  justify-self: center;
  align-self: center;
  width: 136px;
  height: 136px;
  margin: 0 auto;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, #071427 54%, transparent 55%),
    conic-gradient(from 270deg, var(--dial-color) calc(var(--score) * 1%), rgba(255, 255, 255, .12) 0);
  box-shadow:
    0 0 28px color-mix(in srgb, var(--dial-color) 48%, transparent),
    inset 0 0 22px rgba(255, 255, 255, .05);
  animation: dialPop .7s ease both, dialPulse 2.8s ease-in-out infinite;
}

.nc-mini-dial::before {
  background:
    conic-gradient(from 270deg, var(--dial-color) calc(var(--score) * 1%), rgba(255, 255, 255, .12) 0);
  animation: dialSweep 1.1s ease both;
}

.nc-mini-dial::after {
  inset: 13px;
  background:
    radial-gradient(circle at 35% 20%, rgba(255, 255, 255, .13), transparent 32%),
    #071427;
}

.nc-mini-dial strong {
  font-size: 31px;
  color: #fff;
  text-shadow: 0 0 14px var(--dial-color);
}

.nc-mini-dial small {
  font-size: 12px;
  color: #b9c8ee;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.nc-signal-card p {
  text-align: center;
  font-size: 15px;
  line-height: 1.6;
  color: #b9c3dd;
  margin: 0;
}

.nc-card-link {
  color: var(--dial-color);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  align-self: end;
}

.nc-signal-card:nth-child(1) {
  --dial-color: #18f2d1;
}

.nc-signal-card:nth-child(2) {
  --dial-color: #2d83ff;
}

.nc-signal-card:nth-child(3) {
  --dial-color: #7165ff;
}

.nc-signal-card:nth-child(4) {
  --dial-color: #9b5cff;
}

.nc-signal-card:nth-child(5) {
  --dial-color: #f046c7;
}

.nc-signal-card:nth-child(6) {
  --dial-color: #ff5d69;
}

.nc-signal-card:nth-child(7) {
  --dial-color: #ff8616;
}

.nc-signal-card:nth-child(8) {
  --dial-color: #ffd719;
}

.nc-signal-card:nth-child(9) {
  --dial-color: #5ee54f;
}

.nc-signal-card:nth-child(10) {
  --dial-color: #20e4df;
}

.nc-signal-card:nth-child(1) .nc-mini-dial {
  animation-delay: .02s;
}

.nc-signal-card:nth-child(2) .nc-mini-dial {
  animation-delay: .08s;
}

.nc-signal-card:nth-child(3) .nc-mini-dial {
  animation-delay: .14s;
}

.nc-signal-card:nth-child(4) .nc-mini-dial {
  animation-delay: .20s;
}

.nc-signal-card:nth-child(5) .nc-mini-dial {
  animation-delay: .26s;
}

.nc-signal-card:nth-child(6) .nc-mini-dial {
  animation-delay: .32s;
}

.nc-signal-card:nth-child(7) .nc-mini-dial {
  animation-delay: .38s;
}

.nc-signal-card:nth-child(8) .nc-mini-dial {
  animation-delay: .44s;
}

.nc-signal-card:nth-child(9) .nc-mini-dial {
  animation-delay: .50s;
}

.nc-signal-card:nth-child(10) .nc-mini-dial {
  animation-delay: .56s;
}

/* =========================================================
   FINAL RESPONSIVE SIGNAL RUN
   Dark million-dollar Neurocompute card row
   ========================================================= */

.nc-section#signals {
  overflow: hidden;
}

.nc-signal-row {
  --card-gap: 18px;
  display: grid;
  grid-template-columns: repeat(10, minmax(118px, 1fr));
  gap: var(--card-gap);
  overflow-x: auto;
  padding: 22px 0 34px;
  align-items: stretch;
  scrollbar-color: rgba(130, 160, 220, .35) rgba(255, 255, 255, .04);
}

.nc-signal-card {
  position: relative;
  min-width: 118px;
  height: 610px;
  padding: 24px 16px 22px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 70%, color-mix(in srgb, var(--dial-color) 12%, transparent), transparent 34%),
    linear-gradient(180deg, rgba(13, 28, 55, .96), rgba(5, 12, 25, .99));
  border: 1px solid rgba(88, 140, 255, .25);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .05),
    0 22px 60px rgba(0, 0, 0, .38);
  display: grid;
  grid-template-rows: 54px 280px 150px 74px 34px;
  align-items: start;
  overflow: hidden;
}

.nc-rank {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 21px;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(135deg, color-mix(in srgb, var(--dial-color) 72%, white), var(--dial-color));
  box-shadow:
    0 0 18px color-mix(in srgb, var(--dial-color) 75%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, .35);
}

.nc-signal-title {
  color: #fff;
  text-decoration: none;
  font-size: clamp(14px, .86vw, 18px);
  font-weight: 900;
  line-height: 1.43;
  min-height: 280px;
  max-height: 280px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 11;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
  overflow-wrap: anywhere;
}

.nc-mini-dial {
  justify-self: center;
  align-self: end;
  width: clamp(94px, 7.5vw, 132px);
  height: clamp(94px, 7.5vw, 132px);
  margin: 18px auto 0;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, #071427 54%, transparent 55%),
    conic-gradient(from 270deg, var(--dial-color) calc(var(--score) * 1%), rgba(255, 255, 255, .12) 0);
  box-shadow:
    0 0 30px color-mix(in srgb, var(--dial-color) 48%, transparent),
    inset 0 0 22px rgba(255, 255, 255, .05);
  animation: ncDialPop .72s ease both, ncDialPulse 2.8s ease-in-out infinite;
}

.nc-mini-dial::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    conic-gradient(from 270deg, var(--dial-color) calc(var(--score) * 1%), rgba(255, 255, 255, .12) 0);
  animation: ncDialSweep 1.12s cubic-bezier(.2, .8, .2, 1) both;
}

.nc-mini-dial::after {
  content: "";
  position: absolute;
  inset: 13px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 20%, rgba(255, 255, 255, .13), transparent 32%),
    #071427;
}

.nc-mini-dial>div,
.nc-mini-dial strong,
.nc-mini-dial small {
  position: relative;
  z-index: 2;
  text-align: center;
}

.nc-mini-dial strong {
  display: block;
  font-size: clamp(24px, 1.85vw, 31px);
  color: #fff;
  text-shadow: 0 0 14px var(--dial-color);
}

.nc-mini-dial small {
  display: block;
  font-size: 11px;
  color: #b9c8ee;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.nc-signal-card p {
  text-align: center;
  color: #b9c3dd;
  font-size: clamp(12px, .78vw, 15px);
  line-height: 1.55;
  margin: 0;
  align-self: center;
}

.nc-card-link {
  color: var(--dial-color);
  font-size: clamp(12px, .82vw, 15px);
  font-weight: 900;
  text-decoration: none;
  align-self: end;
  white-space: nowrap;
  text-shadow: 0 0 12px color-mix(in srgb, var(--dial-color) 35%, transparent);
}

.nc-signal-card:nth-child(1) {
  --dial-color: #18f2d1;
}

.nc-signal-card:nth-child(2) {
  --dial-color: #2d83ff;
}

.nc-signal-card:nth-child(3) {
  --dial-color: #7165ff;
}

.nc-signal-card:nth-child(4) {
  --dial-color: #9b5cff;
}

.nc-signal-card:nth-child(5) {
  --dial-color: #f046c7;
}

.nc-signal-card:nth-child(6) {
  --dial-color: #ff5d69;
}

.nc-signal-card:nth-child(7) {
  --dial-color: #ff8616;
}

.nc-signal-card:nth-child(8) {
  --dial-color: #ffd719;
}

.nc-signal-card:nth-child(9) {
  --dial-color: #5ee54f;
}

.nc-signal-card:nth-child(10) {
  --dial-color: #20e4df;
}

.nc-signal-card:nth-child(1) .nc-mini-dial {
  animation-delay: .02s;
}

.nc-signal-card:nth-child(2) .nc-mini-dial {
  animation-delay: .08s;
}

.nc-signal-card:nth-child(3) .nc-mini-dial {
  animation-delay: .14s;
}

.nc-signal-card:nth-child(4) .nc-mini-dial {
  animation-delay: .20s;
}

.nc-signal-card:nth-child(5) .nc-mini-dial {
  animation-delay: .26s;
}

.nc-signal-card:nth-child(6) .nc-mini-dial {
  animation-delay: .32s;
}

.nc-signal-card:nth-child(7) .nc-mini-dial {
  animation-delay: .38s;
}

.nc-signal-card:nth-child(8) .nc-mini-dial {
  animation-delay: .44s;
}

.nc-signal-card:nth-child(9) .nc-mini-dial {
  animation-delay: .50s;
}

.nc-signal-card:nth-child(10) .nc-mini-dial {
  animation-delay: .56s;
}

@keyframes ncDialSweep {
  0% {
    clip-path: circle(0% at 50% 50%);
    transform: rotate(-150deg) scale(.78);
    opacity: 0;
  }

  100% {
    clip-path: circle(80% at 50% 50%);
    transform: rotate(0deg) scale(1);
    opacity: 1;
  }
}

@keyframes ncDialPop {
  0% {
    transform: translateY(26px) scale(.78);
    opacity: 0;
  }

  100% {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

@keyframes ncDialPulse {

  0%,
  100% {
    filter: drop-shadow(0 0 8px color-mix(in srgb, var(--dial-color) 38%, transparent));
  }

  50% {
    filter: drop-shadow(0 0 24px color-mix(in srgb, var(--dial-color) 78%, transparent));
  }
}

/* Responsive: keep the million-dollar row on desktop, scroll on smaller screens */

@media (max-width: 1500px) {
  .nc-signal-row {
    grid-template-columns: repeat(10, 150px);
  }

  .nc-signal-card {
    height: 560px;
    grid-template-rows: 50px 240px 142px 70px 34px;
  }

  .nc-signal-title {
    min-height: 240px;
    max-height: 240px;
    -webkit-line-clamp: 10;
  }
}

@media (max-width: 1100px) {
  .nc-signal-row {
    grid-template-columns: repeat(10, 145px);
  }

  .nc-signal-card {
    height: 540px;
    padding: 22px 15px 20px;
    grid-template-rows: 48px 230px 136px 68px 34px;
  }

  .nc-signal-title {
    min-height: 230px;
    max-height: 230px;
    -webkit-line-clamp: 9;
  }
}

@media (max-width: 760px) {
  .nc-signal-row {
    grid-template-columns: repeat(10, 72vw);
    gap: 16px;
    scroll-snap-type: x mandatory;
    padding-bottom: 28px;
  }

  .nc-signal-card {
    scroll-snap-align: start;
    height: 520px;
    grid-template-rows: 50px 210px 135px 70px 34px;
  }

  .nc-signal-title {
    font-size: 18px;
    min-height: 210px;
    max-height: 210px;
    -webkit-line-clamp: 8;
  }

  .nc-mini-dial {
    width: 126px;
    height: 126px;
  }
}

@media (orientation: landscape) and (max-width: 950px) {
  .nc-signal-row {
    grid-template-columns: repeat(10, 155px);
  }

  .nc-signal-card {
    height: 500px;
    grid-template-rows: 46px 200px 128px 64px 32px;
  }

  .nc-signal-title {
    min-height: 200px;
    max-height: 200px;
    -webkit-line-clamp: 8;
  }

  .nc-mini-dial {
    width: 118px;
    height: 118px;
  }
}

/* FULL WIDTH SIGNAL SECTION */

#signals {
  width: 100%;
}

#signals .nc-section-head,
#signals .nc-signal-row {
  width: 100%;
  max-width: none;
}

.nc-signal-row {
  display: grid;
  grid-template-columns: repeat(10, minmax(135px, 1fr));
  width: 100%;
}

.nc-home {
  max-width: 1800px;
  margin: 0 auto;
  padding: 24px 28px;
}

.nc-signal-title {
  overflow: hidden;
  display: block;
  line-height: 1.42;
  height: 15.6em;
  /* fixed title box */
  position: relative;
}

.nc-signal-title::after {
  content: "...";
  position: absolute;
  bottom: 0;
  right: 0;
  padding-left: 8px;
  background: linear-gradient(90deg,
      rgba(7, 20, 39, 0),
      rgba(7, 20, 39, 1) 45%);
}

/* FULL WIDTH SIGNAL AREA + CLEAN ELLIPSIS FIX */

.nc-home {
  max-width: none !important;
  width: 100% !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
}

.nc-section#signals {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

#signals .nc-section-head {
  width: 100%;
  max-width: none;
}

.nc-signal-row {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(10, minmax(132px, 1fr)) !important;
  gap: 16px !important;
  overflow-x: auto;
}

/* Bigger columns because page now uses full browser width */
.nc-signal-card {
  min-width: 0 !important;
  width: auto !important;
  height: 585px !important;
  padding: 22px 16px 20px !important;
  grid-template-rows: 52px 245px 150px 70px 34px !important;
}

/* Better ellipsis: fade + fixed text box */
.nc-signal-title {
  position: relative !important;
  display: block !important;
  height: 245px !important;
  min-height: 245px !important;
  max-height: 245px !important;
  overflow: hidden !important;
  font-size: clamp(14px, .95vw, 17px) !important;
  line-height: 1.42 !important;
  font-weight: 900 !important;
}

/* remove browser line-clamp behavior */
.nc-signal-title {
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
}

/* clean visible ending */
.nc-signal-title::after {
  content: "...";
  position: absolute;
  right: 0;
  bottom: 0;
  padding-left: 22px;
  color: #fff;
  font-weight: 900;
  background: linear-gradient(90deg,
      rgba(7, 15, 30, 0),
      rgba(7, 15, 30, .92) 35%,
      rgba(7, 15, 30, 1) 100%);
}

/* push circles down slightly */
.nc-mini-dial {
  align-self: end !important;
  margin-top: 28px !important;
  margin-bottom: 0 !important;
}

/* responsive tablet / landscape */
@media (max-width:1200px) {
  .nc-home {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .nc-signal-row {
    grid-template-columns: repeat(10, 145px) !important;
  }
}

/* portrait mobile: scroll cards */
@media (max-width:760px) {
  .nc-signal-row {
    grid-template-columns: repeat(10, 76vw) !important;
    gap: 16px !important;
    scroll-snap-type: x mandatory;
  }

  .nc-signal-card {
    scroll-snap-align: start;
    height: 540px !important;
  }

  .nc-signal-title {
    height: 220px !important;
    min-height: 220px !important;
    max-height: 220px !important;
    font-size: 18px !important;
  }
}

/* phone landscape */
@media (orientation:landscape) and (max-width:950px) {
  .nc-signal-row {
    grid-template-columns: repeat(10, 150px) !important;
  }

  .nc-signal-card {
    height: 510px !important;
    grid-template-rows: 48px 205px 138px 66px 32px !important;
  }

  .nc-signal-title {
    height: 205px !important;
    min-height: 205px !important;
    max-height: 205px !important;
  }
}