/* =================================================================
   CONTRABIM · Homepage V2 — components added per client feedback
   Layers on top of styles.css + pages.css.
   ================================================================= */

/* ─── Hero tweaks: marquee kept, proof row removed ────────────── */
.v2-hero-ctas { margin-bottom: 8px; }
.nav-signin { white-space: nowrap; }

/* ─── Routing — clean image cards (Enterprise, improved) ──────── */
.rt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.rt-card {
  position: relative; display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; background: #fff; cursor: pointer;
  transition: border-color .2s ease, transform .25s ease, box-shadow .25s ease;
}
.rt-card:hover { border-color: var(--blue); transform: translateY(-4px); box-shadow: 0 34px 60px -34px rgba(0,114,206,.35); }
.rt-media { position: relative; aspect-ratio: 16/11; overflow: hidden; background: #0a2032; }
.rt-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(.4) contrast(1.06) brightness(.82); transition: transform .6s ease, filter .5s ease; }
.rt-card:hover .rt-img { transform: scale(1.05); filter: grayscale(.15) brightness(.95); }
.rt-media::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,22,38,.05) 30%, rgba(5,22,38,.72) 100%); }
.rt-num { position: absolute; top: 14px; left: 16px; z-index: 2; font-family: var(--mono); font-size: 9.5px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.85); }
.rt-icon { position: absolute; right: 16px; top: 14px; z-index: 2; width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.35); border-radius: 8px; background: rgba(5,22,38,.35); backdrop-filter: blur(6px); color: #fff; }
.rt-icon svg { width: 17px; height: 17px; }
.rt-overcap { position: absolute; left: 16px; right: 16px; bottom: 14px; z-index: 2; }
.rt-cat { font-size: 9px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--orange); margin-bottom: 4px; }
.rt-h { font-size: 20px; font-weight: 700; color: #fff; line-height: 1.15; letter-spacing: -.01em; }
.rt-body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.rt-p { font-size: 13.5px; line-height: 1.65; color: var(--text-muted); font-weight: 300; margin: 0 0 20px; }
.rt-link { margin-top: auto; font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--blue); display: inline-flex; align-items: center; gap: 7px; }
.rt-link .ar { transition: transform .2s ease; }
.rt-card:hover .rt-link .ar { transform: translateX(4px); }

/* ─── Authority — light horizontal strip ──────────────────────── */
.authlite { display: grid; grid-template-columns: 1.1fr 2fr; gap: 56px; align-items: center; }
.al-head .eyebrow { margin-bottom: 14px; }
.al-h { font-size: clamp(26px, 3vw, 38px); font-weight: 800; letter-spacing: -.02em; line-height: 1.08; color: var(--dark); margin: 0 0 14px; }
.al-h .lt-blue { color: var(--blue); }
.al-sub { font-size: 14.5px; line-height: 1.7; color: var(--text-muted); font-weight: 300; max-width: 360px; margin: 0; }
.al-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border-lt); border: 1px solid var(--border-lt); border-radius: var(--radius); overflow: hidden; }
.al-cell { background: #fff; padding: 26px 24px; }
.al-num { font-size: 30px; font-weight: 800; letter-spacing: -.02em; color: var(--dark); line-height: 1; }
.al-num .u { font-size: 16px; font-weight: 600; color: var(--blue); }
.al-num .sub { font-size: 16px; font-weight: 600; color: var(--text-muted); }
.al-lab { font-size: 11px; font-weight: 300; color: var(--text-muted); margin-top: 10px; line-height: 1.5; }
.al-cell .k { font-family: var(--mono); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--blue); margin-bottom: 12px; }

/* ─── System — interactive tabbed explorer ────────────────────── */
.sys-tabs { display: flex; flex-wrap: wrap; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 44px; }
.st {
  background: none; border: none; font-family: 'Montserrat', sans-serif;
  font-weight: 600; font-size: 12.5px; letter-spacing: .01em;
  color: var(--text-muted); padding: 16px 22px 18px; cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  display: inline-flex; align-items: center; gap: 10px;
  transition: color .15s ease, border-color .15s ease;
}
.st:hover { color: var(--text); }
.st.active { color: var(--blue); border-bottom-color: var(--blue); }
.st .st-i { width: 20px; height: 20px; display: grid; place-items: center; border: 1px solid currentColor; border-radius: 5px; opacity: .65; }
.st .st-i svg { width: 12px; height: 12px; }

.sys-panel { display: none; }
.sys-panel.is-on { display: block; animation: sysfade .35s ease; }
@keyframes sysfade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.sys-grid { display: grid; grid-template-columns: 1.02fr 1.32fr; gap: 64px; align-items: center; }
.sys-k { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--blue); margin-bottom: 14px; }
.sys-h { font-size: clamp(26px, 2.8vw, 34px); font-weight: 700; letter-spacing: -.015em; line-height: 1.16; margin: 0 0 18px; color: var(--dark); }
.sys-p { font-size: 15px; line-height: 1.72; color: var(--text-muted); font-weight: 300; margin: 0 0 28px; max-width: 440px; }
.sys-list { list-style: none; padding: 0; margin: 0 0 32px; display: flex; flex-direction: column; gap: 16px; }
.sys-list li { display: grid; grid-template-columns: 22px 1fr; gap: 14px; align-items: start; }
.sys-list b { display: block; font-size: 13.5px; font-weight: 700; color: var(--text); margin-bottom: 3px; }
.sys-list em { display: block; font-style: normal; font-size: 12.5px; font-weight: 300; color: var(--text-muted); line-height: 1.55; }
.sys-ck { width: 20px; height: 20px; border-radius: 6px; background: linear-gradient(135deg, #0072CE, #005ea8); display: grid; place-items: center; margin-top: 1px; box-shadow: 0 4px 10px -2px rgba(0,114,206,.4); }
.sys-ck::after { content: ''; width: 9px; height: 5px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg) translate(1px,-1px); }
.sys-actions { display: flex; gap: 14px; flex-wrap: wrap; }

/* mock window */
.sys-mock { background: #fff; border: 1px solid var(--border); border-radius: 14px; box-shadow: 0 40px 80px -34px rgba(5,22,38,.4), 0 12px 24px -14px rgba(5,22,38,.2); overflow: hidden; }
.sm-chrome { display: flex; align-items: center; gap: 6px; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.sm-chrome .smd { width: 9px; height: 9px; border-radius: 50%; }
.sm-chrome .r { background: #ff5f57; } .sm-chrome .y { background: #febc2e; } .sm-chrome .g { background: #28c840; }
.sm-tab { margin-left: 12px; font-family: var(--mono); font-size: 10px; color: var(--text-muted); letter-spacing: .05em; background: var(--light); padding: 5px 10px; border-radius: 4px; }
.sm-body { display: grid; grid-template-columns: 142px 1fr; min-height: 320px; }
.sm-side { border-right: 1px solid var(--border); padding: 14px 12px; background: #fafbfc; }
.sm-side h6 { font-family: var(--mono); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-muted); margin: 0 0 8px; padding: 0 6px; }
.sm-side ul { list-style: none; padding: 0; margin: 0 0 14px; }
.sm-side li { font-family: var(--mono); font-size: 10.5px; color: var(--text-muted); padding: 5px 6px; border-radius: 4px; display: flex; align-items: center; gap: 6px; }
.sm-side li.on { background: rgba(0,114,206,.08); color: var(--blue); font-weight: 600; }
.sm-side li::before { content: ''; width: 6px; height: 6px; background: currentColor; opacity: .45; border-radius: 1px; }
.sm-stage { position: relative; background: radial-gradient(ellipse 70% 60% at 30% 30%, rgba(0,114,206,.06), transparent 70%); padding: 18px 22px; display: flex; align-items: center; justify-content: center; }
.sm-stage svg { width: 100%; height: 268px; display: block; }
.sm-foot { display: flex; justify-content: space-between; padding: 10px 16px; border-top: 1px solid var(--border); font-family: var(--mono); font-size: 10px; color: var(--text-muted); letter-spacing: .05em; }
/* spreadsheet stage variant (light) */
.sm-sheet { width: 100%; border-collapse: collapse; font-family: var(--mono); font-size: 11px; align-self: start; }
.sm-sheet th { text-align: left; font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-muted); padding: 9px 14px; border-bottom: 1px solid var(--border); }
.sm-sheet td { padding: 8px 14px; border-bottom: 1px solid var(--border-lt); color: var(--text); }
.sm-sheet .r { text-align: right; }
.sm-sheet tr.hot td { background: rgba(0,114,206,.07); color: var(--blue); font-weight: 600; }
.sm-stage-fill { padding: 0; align-items: stretch; display: block; }

/* offer ribbon (re-worded) sits on the system note card */
.sys-note { margin-top: 56px; display: grid; grid-template-columns: 1fr auto; gap: 30px; align-items: center; position: relative; overflow: hidden; background: var(--dark); border-radius: var(--radius-lg); padding: 32px 36px; }
.sys-note .bp-grid { opacity: .5; }
.sys-note-ribbon { position: absolute; top: 22px; right: -38px; background: var(--orange); color: #fff; font-size: 9px; font-weight: 800; letter-spacing: .16em; padding: 5px 44px; transform: rotate(45deg); box-shadow: 0 6px 18px -4px rgba(253,98,6,.5); }
.sys-note-l { position: relative; z-index: 1; }
.sys-note-k { font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: #95C7F0; margin-bottom: 10px; }
.sys-note-h { font-size: 21px; font-weight: 700; color: #fff; margin: 0 0 6px; letter-spacing: -.01em; }
.sys-note-p { font-size: 13.5px; color: rgba(255,255,255,.6); font-weight: 300; margin: 0; }
.sys-note-r { position: relative; z-index: 1; display: flex; align-items: baseline; gap: 18px; }
.sys-note-price { color: #fff; font-weight: 800; font-size: 40px; letter-spacing: -.02em; }
.sys-note-price .d { font-size: 20px; color: rgba(255,255,255,.7); font-weight: 600; }
.sys-note-renew { font-size: 11px; color: rgba(255,255,255,.55); line-height: 1.5; }
.sys-note-renew b { color: rgba(149,224,61,.9); font-weight: 600; }

/* ─── Outcomes — solid blue band, readable ────────────────────── */
.out-foot-note { margin-top: 22px; font-family: var(--mono); font-size: 10.5px; letter-spacing: .04em; color: rgba(255,255,255,.4); }
.out-big { font-family: 'Montserrat', sans-serif; font-size: 40px; font-weight: 800; color: #fff; letter-spacing: -.02em; line-height: 1; margin-bottom: 18px; }
.out-big sub { font-size: 18px; font-weight: 600; color: rgba(255,255,255,.55); vertical-align: baseline; }

/* ─── Objections — 2-col accordion ────────────────────────────── */
.faq2 { display: grid; grid-template-columns: .85fr 1.7fr; gap: 56px; align-items: start; }
.faq2-head { position: sticky; top: 90px; }
.faq2-head .section-h2 { margin-top: 12px; }
.faq-trial { margin-top: 16px; display: inline-flex; }

/* ─── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .rt-grid { grid-template-columns: 1fr; }
  .authlite { grid-template-columns: 1fr; gap: 36px; }
  .al-stats { grid-template-columns: repeat(3, 1fr); }
  .sys-grid { grid-template-columns: 1fr; gap: 40px; }
  .sys-note { grid-template-columns: 1fr; gap: 20px; }
  .faq2 { grid-template-columns: 1fr; gap: 28px; }
  .faq2-head { position: static; }
}
@media (max-width: 700px) {
  .al-stats { grid-template-columns: 1fr; }
  .sm-body { grid-template-columns: 1fr; }
  .sys-tabs { flex-wrap: nowrap; overflow-x: auto; }
  .st { white-space: nowrap; }
}
