/* =========================================================
   Components — V3 (editorial, bold, sharp)
   ========================================================= */

/* ---------- Buttons ---------- */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: 1rem 1.55rem;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: var(--track-snug);
  line-height: 1;
  border-radius: var(--r-pill);
  transition:
    transform var(--dur-2) var(--ease-spring),
    background var(--dur-2),
    box-shadow var(--dur-3),
    border-color var(--dur-2),
    color var(--dur-2);
  white-space: nowrap;
  cursor: pointer;
  will-change: transform;
  border: 1px solid transparent;
}
.btn svg {
  width: 1.05em; height: 1.05em;
  transition: transform var(--dur-2) var(--ease-spring);
}
.btn:hover svg { transform: translateX(3px); }
.btn:active { transform: translateY(1px) scale(0.985); }

.btn--primary {
  background: linear-gradient(180deg, var(--blue-hi) 0%, var(--blue) 100%);
  color: #fff;
  box-shadow: var(--shadow-cta), var(--shadow-glass-edge);
}
.btn--primary:hover {
  background: linear-gradient(180deg, #3E8BEB 0%, #2372D8 100%);
  box-shadow: 0 18px 50px -12px rgba(26, 99, 191, 0.65), var(--shadow-glass-edge);
}

.btn--ghost {
  background: rgba(234, 240, 250, 0.03);
  color: var(--text);
  border-color: var(--line-strong);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.btn--ghost:hover {
  background: rgba(234, 240, 250, 0.08);
  border-color: var(--line-bright);
}

.btn--lg { padding: 1.2rem 1.9rem; font-size: 1.02rem; }

/* ---------- Status pill (scarcity) ---------- */
.status {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.55rem 1rem 0.55rem 0.8rem;
  border-radius: var(--r-pill);
  background: rgba(52, 211, 127, 0.08);
  border: 1px solid rgba(52, 211, 127, 0.25);
  color: var(--success);
  font-size: 0.88rem;
  font-weight: 500;
  letter-spacing: var(--track-snug);
}
.status__dot {
  position: relative;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 0 0 rgba(52, 211, 127, 0.6);
  animation: pulse 2.2s var(--ease-out-expo) infinite;
  flex-shrink: 0;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(52, 211, 127, 0.55); }
  70%  { box-shadow: 0 0 0 8px rgba(52, 211, 127, 0); }
  100% { box-shadow: 0 0 0 0 rgba(52, 211, 127, 0); }
}

.status--ice {
  background: rgba(222, 232, 246, 0.05);
  border-color: var(--line-strong);
  color: var(--text-muted);
}

/* ---------- Glass panel ---------- */
.glass {
  position: relative;
  background: linear-gradient(180deg, rgba(234, 240, 250, 0.04) 0%, rgba(234, 240, 250, 0.02) 100%);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-2xl);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--shadow-md), var(--shadow-glass-edge);
  overflow: hidden;
}
.glass::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 0%, rgba(255, 255, 255, 0.06), transparent 55%);
  pointer-events: none;
}

/* ---------- Reassurance line ---------- */
.reassurances {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  margin-top: var(--s-5);
  color: var(--text-muted);
  font-size: 0.95rem;
}
.reassurances li {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.check-ic, .cross-ic {
  width: 1.15em; height: 1.15em;
  flex-shrink: 0;
}
.check-ic { color: var(--blue-hi); }
.cross-ic { color: var(--danger); }

/* ---------- Accordion (FAQ) ---------- */
.accordion { border-top: 1px solid var(--line-strong); }
.accordion__item { border-bottom: 1px solid var(--line-strong); }

.accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  width: 100%;
  padding: clamp(1.3rem, 1rem + 0.7vw, 1.85rem) 0;
  text-align: left;
  font-family: inherit;
  font-size: clamp(1.1rem, 0.98rem + 0.45vw, 1.35rem);
  font-weight: 600;
  color: var(--text);
  letter-spacing: var(--track-tight);
  line-height: 1.3;
  transition: color var(--dur-2);
}
.accordion__trigger:hover { color: var(--blue-hi); }

.accordion__chevron {
  flex-shrink: 0;
  width: 2.1rem; height: 2.1rem;
  border-radius: var(--r-sm);
  background: rgba(234, 240, 250, 0.04);
  border: 1px solid var(--line-strong);
  color: var(--ice-dim);
  display: grid;
  place-items: center;
  font-size: 1.1rem;
  font-weight: 500;
  transition: background var(--dur-2), color var(--dur-2), transform var(--dur-3) var(--ease-spring), border-color var(--dur-2);
}
.accordion__chevron::before { content: "+"; }
.accordion__item.is-open .accordion__chevron {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
  transform: rotate(45deg);
}

.accordion__trigger-label {
  display: inline-flex;
  align-items: baseline;
  gap: 1rem;
}
.accordion__trigger-label::before {
  content: attr(data-ix);
  font-size: 0.85rem;
  color: var(--blue-hi);
  font-weight: 700;
  letter-spacing: var(--track-snug);
  font-variant-numeric: tabular-nums;
}

.accordion__panel {
  overflow: hidden;
  max-height: 0;
  transition: max-height var(--dur-4) var(--ease-out-expo);
}
.accordion__item.is-open .accordion__panel { max-height: 800px; }
.accordion__content {
  padding: 0 0 1.85rem 2.2rem;
  color: var(--text-muted);
  font-size: 1.02rem;
  line-height: 1.7;
  max-width: 62ch;
}

/* ---------- Marquee ---------- */
.marquee {
  position: relative;
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}
.marquee__track {
  display: flex;
  gap: clamp(3rem, 2rem + 3vw, 5rem);
  width: max-content;
  animation: marquee-scroll 45s linear infinite;
}
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  height: 2.2rem;
  opacity: 0.5;
  color: var(--ice);
  transition: opacity var(--dur-2);
}
.marquee__item:hover { opacity: 1; }
.marquee__item svg, .marquee__item img { height: 100%; width: auto; }
.marquee__item img { filter: brightness(0) invert(1); }
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------- Sparkline ---------- */
.spark {
  width: 100%;
  height: 2.5rem;
  margin-top: var(--s-3);
}
.spark path.line {
  fill: none;
  stroke: var(--blue-hi);
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 4px rgba(26, 99, 191, 0.5));
  stroke-dasharray: 200;
  stroke-dashoffset: 200;
  animation: spark-draw 1.6s var(--ease-out-expo) forwards;
  animation-delay: 0.3s;
}
.spark path.fill {
  fill: url(#spark-gradient);
  opacity: 0;
  animation: fade-in 1s var(--ease-out-expo) forwards;
  animation-delay: 1.2s;
}
@keyframes spark-draw { to { stroke-dashoffset: 0; } }
@keyframes fade-in { to { opacity: 1; } }

/* ---------- Shimmer bar ---------- */
.shimmer-bar {
  position: relative;
  height: 4px;
  border-radius: var(--r-pill);
  background: rgba(234, 240, 250, 0.06);
  overflow: hidden;
}
.shimmer-bar::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 40%;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(26, 99, 191, 0.6) 45%,
    var(--blue-hi) 50%,
    rgba(26, 99, 191, 0.6) 55%,
    transparent 100%);
  animation: shimmer 2.6s ease-in-out infinite;
}
@keyframes shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(350%); }
}

/* ---------- Case card ---------- */
.case {
  position: relative;
  padding: clamp(1.75rem, 1.3rem + 1.3vw, 2.5rem);
  background: var(--ink-800);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  overflow: hidden;
  transition: border-color var(--dur-2), transform var(--dur-3) var(--ease-spring);
}
.case::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 2px;
  background: linear-gradient(90deg, transparent, var(--blue-hi), transparent);
  opacity: 0;
  transition: opacity var(--dur-2);
}
.case:hover {
  border-color: rgba(26, 99, 191, 0.35);
  transform: translateY(-3px);
}
.case:hover::before { opacity: 1; }

.case__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: var(--s-5);
  padding-bottom: var(--s-4);
  border-bottom: 1px solid var(--line);
}
.case__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  color: #fff;
}
.case__brand svg, .case__brand img { height: 1.4rem; width: auto; }
.case__brand img { filter: brightness(0) invert(1); }
.case__brand-name {
  font-weight: 700;
  font-size: 1.15rem;
  letter-spacing: var(--track-snug);
}
.case__sector {
  font-size: 0.85rem;
  color: var(--text-subtle);
  text-align: right;
  max-width: 16rem;
  line-height: 1.4;
}
.case__results { display: grid; gap: var(--s-3); }
.case__result {
  display: flex;
  align-items: baseline;
  gap: var(--s-4);
  padding-block: 0.3rem;
}
.case__result-value {
  font-size: clamp(1.65rem, 1.4rem + 0.8vw, 2.1rem);
  font-weight: 800;
  color: var(--blue-hi);
  letter-spacing: var(--track-ultra);
  line-height: 1;
  min-width: 5.5rem;
  font-variant-numeric: tabular-nums;
}
.case__result-label {
  color: var(--text-muted);
  line-height: 1.4;
  font-size: 0.96rem;
}

.case__change {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--line);
  font-style: italic;
  color: var(--ice);
  font-size: 1.02rem;
  line-height: 1.5;
  letter-spacing: var(--track-snug);
}

.case__link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: var(--s-4);
  color: var(--blue-hi);
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: var(--track-snug);
  transition: gap var(--dur-2) var(--ease-spring), color var(--dur-2);
}
.case__link:hover { gap: 0.7rem; color: var(--text); }
.case__link::after { content: "→"; }

/* ---------- Pillar ---------- */
.pillar {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: clamp(1.75rem, 1.3rem + 1.2vw, 2.5rem);
  background: var(--ink-800);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  transition: border-color var(--dur-2), transform var(--dur-3) var(--ease-spring);
  overflow: hidden;
}
.pillar:hover {
  border-color: rgba(26, 99, 191, 0.35);
  transform: translateY(-3px);
}
.pillar__num {
  display: block;
  font-size: clamp(2.5rem, 2rem + 1.5vw, 3.2rem);
  font-weight: 800;
  line-height: 0.9;
  letter-spacing: var(--track-ultra);
  background: linear-gradient(180deg, var(--ice) 0%, rgba(222, 232, 246, 0.35) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: var(--s-4);
  font-variant-numeric: tabular-nums;
}
.pillar__title {
  font-size: clamp(1.35rem, 1.15rem + 0.5vw, 1.65rem);
  font-weight: 700;
  color: #fff;
  letter-spacing: var(--track-tight);
  line-height: 1.15;
  margin-bottom: var(--s-3);
}
.pillar__desc {
  color: var(--text-muted);
  font-size: 1rem;
  line-height: 1.5;
  margin-bottom: var(--s-5);
}
.pillar__list {
  margin-top: auto;
  border-top: 1px solid var(--line);
}
.pillar__list li {
  padding: 0.8rem 0;
  border-bottom: 1px solid var(--line);
  font-size: 0.98rem;
  color: var(--ice-dim);
  display: flex;
  align-items: flex-start;
  gap: 0.8rem;
  line-height: 1.4;
}
.pillar__list li::before {
  content: "";
  flex-shrink: 0;
  width: 0.5rem;
  height: 0.5rem;
  margin-top: 0.55rem;
  border-radius: 50%;
  background: var(--blue-hi);
}
.pillar__list li:last-child { border-bottom: none; }

/* ---------- Quote ---------- */
.quote {
  position: relative;
  padding-block: clamp(3rem, 2rem + 2.5vw, 5rem);
  max-width: 68rem;
}
.quote__body {
  position: relative;
  z-index: 1;
  font-size: clamp(1.55rem, 1.2rem + 1.3vw, 2.25rem);
  line-height: 1.3;
  letter-spacing: var(--track-tight);
  color: #fff;
  font-weight: 600;
}
.quote__body::before {
  content: "\201C";
  position: absolute;
  top: -0.4em;
  left: -0.1em;
  font-size: 4.5em;
  line-height: 0.8;
  color: var(--blue);
  opacity: 0.35;
  font-family: Georgia, serif;
}
.quote__attribution {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  margin-top: var(--s-5);
  font-size: 0.95rem;
  color: var(--text-subtle);
  letter-spacing: var(--track-snug);
}
.quote__attribution strong {
  color: var(--ice);
  font-weight: 700;
}
.quote__attribution::before {
  content: "";
  width: 2.2rem;
  height: 2px;
  background: var(--blue-hi);
}

/* ---------- Form ---------- */
.form {
  display: grid;
  gap: var(--s-5);
}
.field {
  display: grid;
  gap: 0.5rem;
}
.field__label {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--ice-dim);
}
.field__label .field__req {
  color: var(--blue-hi);
  margin-left: 0.15rem;
}
.field__control {
  width: 100%;
  padding: 0.95rem 1.05rem;
  background: rgba(5, 11, 24, 0.55);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  color: var(--text);
  font-size: 1rem;
  line-height: 1.4;
  letter-spacing: var(--track-snug);
  transition: border-color var(--dur-2), background var(--dur-2), box-shadow var(--dur-2);
}
.field__control::placeholder {
  color: var(--text-subtle);
}
.field__control:hover {
  border-color: var(--line-bright);
}
.field__control:focus {
  outline: none;
  border-color: var(--blue-hi);
  background: rgba(5, 11, 24, 0.8);
  box-shadow: 0 0 0 3px rgba(45, 124, 224, 0.18);
}
.field__control:focus-visible {
  outline: none;
}
textarea.field__control {
  resize: vertical;
  min-height: 8rem;
  font-family: inherit;
}
select.field__control {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232D7CE0' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 1.1rem center;
  padding-right: 2.75rem;
  cursor: pointer;
}
.field__help {
  font-size: 0.82rem;
  color: var(--text-subtle);
  line-height: 1.45;
}
.field__label .field__opt {
  color: var(--text-subtle);
  font-weight: 500;
  text-transform: none;
  letter-spacing: var(--track-snug);
  margin-left: 0.4rem;
}
