/* =========================================================================
   CIN Voice Card — premium briefing component
   Used across every terminal page. Self-contained — no external deps.
   ========================================================================= */

.cv-card{
  position:relative;
  background:linear-gradient(180deg,#0c1410 0%,#0a100c 100%);
  border:1px solid #1f3528;
  border-radius:10px;
  padding:22px 24px 24px;
  margin:18px 24px;
  max-width:1200px;
  margin-left:auto;margin-right:auto;
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(34,255,136,0.04), 0 12px 36px rgba(0,0,0,0.45);
  isolation:isolate;
}
.cv-card::before{
  /* soft animated glow stripe on top edge */
  content:"";
  position:absolute;inset:-1px -1px auto -1px;height:2px;
  background:linear-gradient(90deg,transparent 0%,#22ff88 25%,#22ff88 75%,transparent 100%);
  opacity:.55;
  animation:cv-pulse 5.5s ease-in-out infinite;
  pointer-events:none;
}
.cv-card::after{
  /* radial wash */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 600px 200px at 50% 0%, rgba(34,255,136,0.06), transparent 70%);
  z-index:-1;
}
@keyframes cv-pulse{ 0%,100%{opacity:.35} 50%{opacity:.85} }

.cv-card-head{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-bottom:10px;
}
.cv-live{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#22ff88;
}
.cv-live-dot{
  width:6px;height:6px;border-radius:50%;background:#22ff88;
  box-shadow:0 0 8px #22ff88, 0 0 16px rgba(34,255,136,.45);
  animation:cv-blink 1.6s ease-in-out infinite;
}
@keyframes cv-blink{ 0%,100%{opacity:1} 50%{opacity:.35} }
.cv-label{
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.cv-badge{
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-size:9px;font-weight:700;letter-spacing:.08em;
  color:#22ff88;background:rgba(34,255,136,.10);
  padding:3px 8px;border-radius:3px;border:1px solid rgba(34,255,136,.22);
}
.cv-time{
  margin-left:auto;
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-size:10px;color:rgba(255,255,255,.35);letter-spacing:.04em;
}

.cv-headline{
  font-family:var(--font-display, "DM Serif Display", Georgia, serif);
  font-size:clamp(20px, 2.2vw, 28px);
  font-weight:700;line-height:1.18;
  color:#f0f3ef;margin:6px 0 12px;
  letter-spacing:-.01em;
}

.cv-body{
  font-family:var(--font-body, "Inter", system-ui, sans-serif);
  font-size:14.5px;line-height:1.72;
  color:rgba(232,236,230,.86);
}
.cv-body p{ margin:0 0 14px }
.cv-body p:last-child{ margin-bottom:0 }
.cv-body strong{ color:#fff }
.cv-body em{ color:rgba(255,255,255,.7) }
.cv-body .cv-ticker{
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-weight:700;color:#22ff88;letter-spacing:.02em;
}
.cv-body h3{
  font-family:var(--font-display, "DM Serif Display", Georgia, serif);
  font-size:17px;color:#e0ece4;margin:20px 0 8px;font-weight:700;letter-spacing:-.005em;
}
.cv-body ul{ margin:6px 0 14px 18px;padding:0 }
.cv-body li{ margin:4px 0;color:rgba(232,236,230,.84) }

.cv-cta{
  margin-top:18px;
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
}
.cv-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:#22ff88;color:#031b0d;
  border:none;border-radius:6px;
  padding:11px 18px;
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-size:11.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  box-shadow:0 0 0 1px rgba(34,255,136,.4), 0 8px 24px rgba(34,255,136,.18);
}
.cv-btn:hover{ transform:translateY(-1px); background:#3affa0; box-shadow:0 0 0 1px rgba(34,255,136,.55), 0 12px 32px rgba(34,255,136,.28); }
.cv-btn:active{ transform:translateY(0) }
.cv-btn-ghost{
  background:transparent;color:#22ff88;
  border:1px solid rgba(34,255,136,.35);
  box-shadow:none;
}
.cv-btn-ghost:hover{ background:rgba(34,255,136,.08); }

.cv-form{
  margin-top:14px;display:none;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(34,255,136,.18);
  border-radius:8px;padding:14px;
}
.cv-form.is-open{ display:block }
.cv-form-row{ display:flex;gap:8px;flex-wrap:wrap }
.cv-form input[type=email]{
  flex:1 1 240px;min-width:200px;
  background:#0b1411;border:1px solid #1f3528;border-radius:6px;
  padding:11px 12px;color:#e8ece6;
  font-family:var(--font-body, "Inter", system-ui, sans-serif);
  font-size:14px;outline:none;
}
.cv-form input[type=email]:focus{ border-color:#22ff88;box-shadow:0 0 0 2px rgba(34,255,136,.18) }
.cv-form-copy{
  margin:0 0 10px;font-family:var(--font-body, "Inter", system-ui, sans-serif);
  font-size:13px;color:rgba(232,236,230,.78);line-height:1.5;
}
.cv-form-copy strong{ color:#fff }
.cv-form-msg{ margin-top:8px;font-size:12.5px;color:#22ff88;font-family:var(--font-mono, ui-monospace, Menlo, monospace) }
.cv-form-msg.is-err{ color:#ff7575 }

/* Loading skeleton */
.cv-skel{
  height:14px;border-radius:3px;
  background:linear-gradient(90deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.10) 50%, rgba(255,255,255,.05) 100%);
  background-size:200% 100%;
  animation:cv-shimmer 1.4s linear infinite;
  margin:8px 0;
}
@keyframes cv-shimmer{ 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.cv-skel.w70{ width:70% }.cv-skel.w90{ width:90% }.cv-skel.w50{ width:50% }
.cv-skel.h28{ height:28px;margin:10px 0 14px }

/* ===== Floating "Generate Today's Daily Brief" button (top-right) ===== */
.cv-fab{
  position:fixed;top:84px;right:22px;z-index:60;
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(180deg, #22ff88 0%, #0fcd6a 100%);
  color:#031b0d;border:none;border-radius:999px;
  padding:11px 18px;cursor:pointer;
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 0 0 1px rgba(34,255,136,.45), 0 14px 40px rgba(34,255,136,.28);
  transition:transform .15s ease;
}
.cv-fab:hover{ transform:translateY(-1px) }
.cv-fab svg{ width:14px;height:14px }
@media (max-width:900px){ .cv-fab{ top:74px;right:12px;padding:9px 14px;font-size:10px } }

/* ===== Daily-brief modal ===== */
.cv-modal{
  position:fixed;inset:0;z-index:200;
  display:none;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(6px);
  align-items:center;justify-content:center;padding:24px;
}
.cv-modal.is-open{ display:flex }
.cv-modal-dialog{
  width:min(880px, 100%);max-height:88vh;overflow:auto;
  background:#0a100c;
  border:1px solid #22442e;border-radius:12px;
  padding:28px 32px;
  box-shadow:0 30px 90px rgba(0,0,0,.6), 0 0 0 1px rgba(34,255,136,.06);
  position:relative;
}
.cv-modal-close{
  position:absolute;top:14px;right:14px;
  background:transparent;border:1px solid rgba(255,255,255,.18);
  color:#bcd4c5;width:32px;height:32px;border-radius:50%;
  font-size:16px;cursor:pointer;line-height:0;
}
.cv-modal-close:hover{ color:#fff;border-color:rgba(255,255,255,.4) }
.cv-share{ display:flex;gap:8px;margin-top:18px;flex-wrap:wrap }
.cv-share a, .cv-share button{
  display:inline-flex;align-items:center;gap:6px;
  background:#101a14;border:1px solid #1f3528;color:#cfe7d8;
  padding:8px 12px;border-radius:6px;text-decoration:none;cursor:pointer;
  font-family:var(--font-mono, ui-monospace, Menlo, monospace);
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
}
.cv-share a:hover, .cv-share button:hover{ border-color:#22ff88;color:#22ff88 }
.cv-share svg{ width:13px;height:13px }

@media (max-width:700px){
  .cv-card{ margin:14px 12px;padding:18px 16px 20px }
  .cv-headline{ font-size:20px }
  .cv-modal-dialog{ padding:22px 18px }
}
