/* ===========================================================
   PoliHub API edition — extra styles (index2)
   Code window · endpoints · connectors · api stats · security
   =========================================================== */

/* ---------- API section ---------- */
.api{ background: var(--surface); overflow:hidden; }
.api-grid{ display:grid; grid-template-columns: 1fr 1.05fr; gap: clamp(32px,5vw,72px); align-items:center; }
.api-copy .lede{ color: var(--ink-2); font-size:1.14rem; max-width: 520px; margin-top:6px; }

.endpoints{ display:flex; flex-direction:column; gap:10px; margin:28px 0; }
.endpoint{
  display:flex; align-items:center; gap:13px; padding:13px 16px;
  background: var(--bg); border:1px solid var(--line); border-radius: var(--radius-sm);
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; direction:ltr; justify-content:flex-start;
}
.endpoint .method{ font-weight:700; font-size:.74rem; padding:4px 9px; border-radius:6px; letter-spacing:.04em; }
.endpoint .method.get{ background: color-mix(in srgb,var(--ok) 16%,transparent); color: #0c7349; }
.endpoint .method.post{ background: var(--primary-soft); color: var(--primary-strong); }
.endpoint .path{ font-size:.92rem; color: var(--ink-2); }

.api-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:6px; }

/* ---------- code window ---------- */
.code-win{
  background: #0c1730; border:1px solid #1c2c4d; border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg); overflow:hidden; direction:ltr;
  transform: perspective(1500px) rotateY(4deg); animation: floatCard 7s ease-in-out infinite;
}
.code-bar{ display:flex; align-items:center; gap:8px; padding:14px 16px; background:#0a1226; border-bottom:1px solid #1c2c4d; }
.code-bar .dot{ width:12px; height:12px; border-radius:50%; }
.code-bar .dot.r{ background:#ff5f57; opacity:1; transform:none; } .code-bar .dot.y{ background:#febc2e; } .code-bar .dot.g{ background:#28c840; }
.code-bar .fname{ margin-inline-start:12px; font-family: ui-monospace, Menlo, monospace; font-size:.8rem; color:#7e8db0; }
.code-tabs{ display:flex; gap:0; background:#0a1226; border-bottom:1px solid #1c2c4d; padding:0 10px; }
.code-tabs .tab{ padding:11px 16px; font-family: ui-monospace, Menlo, monospace; font-size:.78rem; color:#6b7aa0; border-bottom:2px solid transparent; cursor:default; }
.code-tabs .tab.on{ color:#bcd0ff; border-bottom-color: var(--primary); }
.code-body{ padding: 22px; font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size:.86rem; line-height:1.85; color:#c7d3ee; overflow-x:auto; }
.code-body .ln{ white-space:pre; }
.code-body .k{ color:#7aa2ff; }   /* key */
.code-body .s{ color:#7ee0b8; }   /* string */
.code-body .n{ color:#f0b86e; }   /* number */
.code-body .c{ color:#5b6b8c; }   /* comment */
.code-body .p{ color:#8593b5; }   /* punctuation */
.code-body .mt{ color:#7ee0b8; font-weight:700; }
.code-resp{ border-top:1px dashed #1c2c4d; margin-top:8px; padding-top:14px; }
.code-resp .badge{ display:inline-block; background: color-mix(in srgb,var(--ok) 18%,transparent); color:#7ee0b8; font-size:.72rem; padding:3px 9px; border-radius:6px; margin-bottom:6px; }

/* ---------- API stats strip ---------- */
.api-stats{ display:grid; grid-template-columns: repeat(4,1fr); gap:18px; margin-top: clamp(40px,5vw,64px); }
.api-stat{ text-align:center; background: var(--bg); border:1px solid var(--line); border-radius: var(--radius); padding:26px 18px; }
.api-stat .big{ font-family: var(--font-head); font-weight:800; font-size: clamp(1.8rem,3vw,2.4rem); color: var(--primary); line-height:1; }
.api-stat .lbl{ color: var(--muted); font-size:.95rem; margin-top:8px; }

/* ---------- security pills ---------- */
.sec-row{ display:flex; flex-wrap:wrap; gap:12px; margin-top:26px; justify-content:center; }
.sec-pill{ display:inline-flex; align-items:center; gap:9px; background: var(--surface); border:1px solid var(--line); border-radius:999px; padding:10px 18px; font-weight:600; font-size:.94rem; color: var(--ink-2); }
.sec-pill .sh{ width:24px;height:24px;border-radius:7px; background: var(--primary-soft); color: var(--primary); display:grid; place-items:center; font-size:.85rem; flex:none; }

/* ---------- docs callout ---------- */
.docs-card{
  display:flex; align-items:center; gap: clamp(20px,3vw,40px); flex-wrap:wrap;
  background: radial-gradient(120% 160% at 90% 0%, #14306b 0%, #0c1a3a 60%, #0a1430 100%);
  color:#fff; border-radius: var(--radius-lg); padding: clamp(30px,4vw,52px); position:relative; overflow:hidden;
  box-shadow: var(--shadow-lg);
}
.docs-card .di{ width:64px; height:64px; border-radius:17px; background: rgba(255,255,255,.12); display:grid; place-items:center; font-size:1.7rem; flex:none; }
.docs-card .dc-txt{ flex:1; min-width: 240px; }
.docs-card h3{ font-size: clamp(1.4rem,2.4vw,2rem); color:#fff; margin-bottom:8px; }
.docs-card p{ color:#c2cfe4; font-size:1.08rem; max-width: 520px; }

/* ---------- connectors ---------- */
.conn-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:20px; }
.conn{
  position:relative; background: var(--surface); border:1px solid var(--line); border-radius: var(--radius);
  padding: 28px; transition: transform .25s, box-shadow .25s, border-color .25s;
}
.conn:hover{ transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: var(--line-strong); }
.conn-top{ display:flex; align-items:center; gap:14px; margin-bottom:16px; }
.conn-logo{
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center; flex:none;
  font-family: var(--font-head); font-weight:800; font-size:1.4rem; color:#fff;
}
.conn-logo.monday{ background: linear-gradient(135deg,#ff3d57,#ffcb00); }
.conn-logo.fireberry{ background: linear-gradient(135deg,#ff6b35,#ff2e63); }
.conn-logo.make{ background: linear-gradient(135deg,#6d3bf5,#b14bf5); }
.conn-logo.zapier{ background: linear-gradient(135deg,#ff4f00,#ff7a3d); }
.conn-logo.connectika{ background: linear-gradient(135deg,#0e9aab,#15a06b); }
.conn-logo.open{ background: linear-gradient(135deg,var(--primary),var(--accent)); }
.conn-top b{ font-family:var(--font-head); font-size:1.18rem; }
.conn-top .tag{ display:block; font-size:.82rem; color:var(--muted); margin-top:2px; }
.conn p{ color: var(--muted); font-size:1rem; }
.conn .c-tick{ position:absolute; top:22px; left:22px; width:24px; height:24px; border-radius:50%; background: color-mix(in srgb,var(--ok) 14%,transparent); color:var(--ok); display:grid; place-items:center; font-size:.78rem; font-weight:800; }

/* ===========================================================
   LEAD FORM (final block)
   =========================================================== */
.lead-card{
  display:grid; grid-template-columns: .9fr 1.1fr; gap: clamp(28px,4vw,56px); align-items:stretch;
  background: radial-gradient(120% 140% at 88% 0%, #1f5fe0 0%, #1746b0 52%, #11357f 100%);
  border-radius: var(--radius-lg); padding: clamp(28px,3.5vw,52px); color:#fff;
  position:relative; overflow:hidden; box-shadow: var(--shadow-lg); text-align:right;
}
.lead-card::before{ content:""; position:absolute; inset:0; background-image: radial-gradient(circle at 12% 120%, rgba(255,255,255,.16), transparent 42%); pointer-events:none; }
.lead-pitch{ position:relative; display:flex; flex-direction:column; }
.lead-pitch .eyebrow{ color:#9ec3ff; } .lead-pitch .eyebrow::before{ background:#9ec3ff; }
.lead-pitch h2{ font-size: clamp(1.9rem,3.4vw,2.9rem); color:#fff; margin:.5rem 0 .8rem; }
.lead-pitch .sub{ color:#cfdcf6; font-size:1.1rem; max-width: 380px; }
.lead-points{ list-style:none; margin:26px 0 0; padding:0; display:flex; flex-direction:column; gap:13px; }
.lead-points li{ display:flex; align-items:center; gap:11px; font-size:1.04rem; font-weight:500; color:#eaf1ff; }
.lead-points .tk{ width:26px; height:26px; border-radius:50%; background: rgba(255,255,255,.16); display:grid; place-items:center; font-size:.82rem; font-weight:800; color:#fff; flex:none; }
.lead-foot{ margin-top:auto; padding-top:26px; display:flex; flex-wrap:wrap; gap:8px 22px; color:#aec4ee; font-size:.96rem; }
.lead-foot a{ color:#fff; font-weight:600; }
.lead-foot .lf-item{ display:flex; align-items:center; gap:8px; }

/* white form card */
.lead-form{ position:relative; background:#fff; border-radius: var(--radius); padding: clamp(22px,2.6vw,32px); box-shadow: 0 20px 50px rgba(8,24,60,.28); color: var(--ink); }
.lf-choice{ position:relative; display:flex; gap:0; background: var(--bg); border:1px solid var(--line); border-radius:999px; padding:5px; margin-bottom:22px; }
.lf-choice button{ position:relative; z-index:1; flex:1 1 0; border:none; background:transparent; border-radius:999px; padding:11px 14px; font-family:var(--font-head); font-weight:600; font-size:.98rem; color: var(--muted); transition: color .25s ease; }
.lf-choice button.on{ color: var(--primary); }
/* sliding highlight thumb */
.lf-choice-thumb{
  position:absolute; z-index:0; top:5px; bottom:5px; right:5px;
  width: calc(50% - 5px);
  background:#fff; border-radius:999px; box-shadow: var(--shadow-sm);
  transition: transform .42s cubic-bezier(.65,.05,.36,1);
  pointer-events:none;
}
.lf-choice[data-active="question"] .lf-choice-thumb{ transform: translateX(-100%); }
@media (prefers-reduced-motion: reduce){
  .lf-choice-thumb{ transition:none; }
}
.lf-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.lf-field{ display:flex; flex-direction:column; margin-bottom:18px; }
.lf-field.full{ margin-bottom:8px; }
.lf-field label{ font-family:var(--font-head); font-weight:600; font-size:.9rem; color: var(--ink-2); margin-bottom:8px; }
.lf-field label .req{ color: var(--primary); margin-inline-start:3px; }
.lf-field input, .lf-field textarea{
  width:100%; font-family:var(--font-body); font-size:1rem; color: var(--ink);
  background:#fff; border:1.5px solid var(--line-strong); border-radius: var(--radius-sm);
  padding:13px 15px; transition: border-color .18s, box-shadow .18s; outline:none;
}
.lf-field textarea{ min-height:120px; resize:vertical; line-height:1.6; }
.lf-field input::placeholder, .lf-field textarea::placeholder{ color:#9aa7bd; }
.lf-field input:focus, .lf-field textarea:focus{ border-color: var(--primary); box-shadow: 0 0 0 4px var(--primary-soft); }
.lf-err{ display:block; color:#d65a4b; font-size:.8rem; font-weight:600; margin-top:6px; }
.lf-submit{ width:100%; margin-top:8px; position:relative; }
.lf-note{ font-size:.82rem; color: var(--muted); text-align:center; margin-top:14px; }

/* submit spinner (shown while "sending") */
.lf-spinner{ display:none; }
.lf-submit.loading{ pointer-events:none; }
.lf-submit.loading > span:not(.lf-spinner){ visibility:hidden; }
.lf-submit.loading .lf-spinner{
  display:block; position:absolute; left:50%; top:50%; width:20px; height:20px; margin:-10px 0 0 -10px;
  border:2.5px solid rgba(255,255,255,.45); border-top-color:#fff; border-radius:50%;
  animation: lfSpin .7s linear infinite;
}
@keyframes lfSpin{ to{ transform: rotate(360deg); } }

/* success state — animated checkmark (matches api_doc.html) */
.lf-success{
  display:none; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  gap:4px; padding:24px 10px 10px;
}
.lead-form.sent{ display:flex; flex-direction:column; justify-content:center; }
.lead-form.sent .lf-success{ display:flex; animation: lfSuccessIn .45s ease both; }
.lf-success h3{ font-family:var(--font-head); font-weight:700; font-size:1.55rem; color: var(--ink); margin:8px 0 0; }
.lf-success p{ color: var(--muted); font-size:1rem; }
@keyframes lfSuccessIn{ from{ opacity:0; transform: translateY(10px); } to{ opacity:1; transform:none; } }

.lf-check{ width:84px; height:84px; display:block; }
.lf-check-circle{
  stroke: var(--ok); stroke-width:3; fill:none;
  stroke-dasharray:151; stroke-dashoffset:151;
  animation: lfCheckCircle .55s cubic-bezier(.65,0,.45,1) .1s forwards;
}
.lf-check-mark{
  stroke: var(--ok); stroke-width:4; fill:none; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:34; stroke-dashoffset:34;
  animation: lfCheckMark .35s cubic-bezier(.65,0,.45,1) .6s forwards;
}
@keyframes lfCheckCircle{ to{ stroke-dashoffset:0; } }
@keyframes lfCheckMark{ to{ stroke-dashoffset:0; } }
@media (prefers-reduced-motion: reduce){
  .lf-success{ animation:none; }
  .lf-check-circle, .lf-check-mark{ animation:none; stroke-dashoffset:0; }
  .lf-submit.loading .lf-spinner{ animation:none; }
}

/* ===========================================================
   LEAD MODAL (header join → popup)
   =========================================================== */
.lead-modal{ position:fixed; inset:0; z-index:1300; display:none; align-items:center; justify-content:center; padding:20px; }
.lead-modal.open{ display:flex; }
.lead-modal-backdrop{ position:absolute; inset:0; background:rgba(8,18,38,.55); backdrop-filter:blur(3px); opacity:0; transition:opacity .25s ease; }
.lead-modal.open .lead-modal-backdrop{ opacity:1; }
.lead-modal-dialog{
  position:relative; width:min(560px,100%); max-height:92vh; overflow-y:auto;
  background:#fff; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  padding: clamp(24px,3.4vw,40px); text-align:right;
  transform: translateY(16px) scale(.97); opacity:0;
  transition: transform .3s cubic-bezier(.2,.7,.2,1), opacity .3s ease;
}
.lead-modal.open .lead-modal-dialog{ transform:none; opacity:1; }
.lead-modal-x{
  position:absolute; top:14px; left:14px; width:36px; height:36px; border:none;
  background: var(--bg); color: var(--muted); border-radius:10px; font-size:1.6rem; line-height:1;
  display:grid; place-items:center; cursor:pointer; transition: background .15s, color .15s;
}
.lead-modal-x:hover{ background: var(--line); color: var(--ink); }
.lead-modal-head{ margin-bottom:22px; padding-inline-end:34px; }
.lead-modal-head h3{ font-family:var(--font-head); font-weight:700; font-size: clamp(1.5rem,3vw,2.05rem); color: var(--ink); margin:.4rem 0 .35rem; }
.lead-modal-head p{ color: var(--muted); font-size:1.02rem; }
/* form inside modal: drop its own card chrome, dialog is the card */
.lead-modal .lead-form{ background:transparent; box-shadow:none; padding:0; border-radius:0; }
.lead-modal .lf-grid{ grid-template-columns: 1fr 1fr; }
.lead-modal .lf-grid .lf-field:last-child{ grid-column: 1 / -1; }
@media (prefers-reduced-motion: reduce){
  .lead-modal-backdrop, .lead-modal-dialog{ transition:none; }
}
@media (max-width: 560px){
  .lead-modal .lf-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 920px){
  .lead-card{ grid-template-columns: 1fr; }
}
@media (max-width: 560px){
  .lf-grid{ grid-template-columns: 1fr; }
  /* keep both API action buttons on one row, shrink to fit */
  .api-actions{ flex-wrap:nowrap; gap:10px; }
  .api-actions .btn{ flex:1 1 0; min-width:0; padding:14px 12px; font-size:.88rem; gap:6px; }
  .api-actions .btn .arr{ display:none; }
}

@media (max-width: 1080px){
  .api-stats{ grid-template-columns: repeat(2,1fr); }
  .conn-grid{ grid-template-columns: repeat(2,1fr); }
}

/* ===========================================================
   TESTIMONIALS — redesigned (index2) · masonry + floating
   =========================================================== */
#reviews .tcards{ display:grid; grid-template-columns: repeat(3,1fr); gap:22px; align-items:start; }
#reviews .tcard{
  break-inside:avoid; margin:0; display:flex; flex-direction:column;
  position:relative; overflow:hidden; padding:30px 28px 26px;
}
#reviews .tcard > *{ position:relative; z-index:1; }
#reviews .tcard .qmark{
  position:absolute; z-index:0; top:6px; left:20px;
  font-family: Georgia, "Times New Roman", serif; font-size:5rem; line-height:1;
  color: var(--primary-soft); pointer-events:none;
  animation: tFloatMark 7s ease-in-out infinite;
}
#reviews .tcard .stars{
  color:#f5a623; letter-spacing:4px; font-size:1.5rem; margin:8px 0 18px;
  display:block; transform-origin:right center;
  animation: tFloatStars 4.5s ease-in-out infinite;
}
#reviews .tcard .quote{ font-size:1.05rem; color: var(--ink-2); flex:1; line-height:1.62; }
#reviews .tcard .t-meta{ display:block; }
#reviews .t-logo{
  align-self:center; margin:2px 0 22px;
  width:170px; height:62px; max-width:82%; flex:none; 
  overflow:hidden; display:flex; align-items:center; justify-content:center; padding:9px 16px;
  animation: tFloatLogo 6s ease-in-out infinite;
}
#reviews .t-logo img{ max-width:100%; max-height:44px; width:auto; height:auto; object-fit:contain; }
html[data-logo-style="bare"] #reviews .t-logo img{ max-height:52px; }
/* bare variant: bigger logo, no box/background */
html[data-logo-style="bare"] #reviews .t-logo{
  width:190px; height:70px; border:0; box-shadow:none;
  background:transparent; --slot-frame-bg:transparent;
}
#reviews .t-meta b{ font-family: var(--font-head); display:block; font-size:1rem; color: var(--ink); }
#reviews .t-meta span{ font-size:.86rem; color: var(--muted); }

/* hover: pause float + lift, feels intentional */
#reviews .tcard:hover{ transform: translateY(-6px); box-shadow: var(--shadow-md); }
#reviews .tcard:hover .qmark,
#reviews .tcard:hover .stars,
#reviews .tcard:hover .t-logo{ animation-play-state: paused; }

/* stagger the float phases per card */
#reviews .tcard:nth-child(3n+1) .stars{ animation-delay:0s; }
#reviews .tcard:nth-child(3n+2) .stars{ animation-delay:.9s; }
#reviews .tcard:nth-child(3n)   .stars{ animation-delay:1.7s; }
#reviews .tcard:nth-child(3n+1) .t-logo{ animation-delay:.4s; }
#reviews .tcard:nth-child(3n+2) .t-logo{ animation-delay:1.3s; }
#reviews .tcard:nth-child(3n)   .t-logo{ animation-delay:2.1s; }
#reviews .tcard:nth-child(odd)  .qmark{ animation-delay:.6s; }

@keyframes tFloatStars{ 0%,100%{ transform: translateY(0) rotate(0); } 50%{ transform: translateY(-5px) rotate(-1.5deg); } }
@keyframes tFloatLogo{ 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-7px); } }
@keyframes tFloatMark{ 0%,100%{ transform: translateY(0) rotate(0); } 50%{ transform: translateY(-9px) rotate(-4deg); } }

@media (prefers-reduced-motion: reduce){
  #reviews .tcard .qmark,
  #reviews .tcard .stars,
  #reviews .t-logo{ animation:none !important; }
}
@media (max-width: 1080px){
  #reviews .tcards{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px){
  #reviews .tcards{ grid-template-columns: 1fr; }
}
@media (max-width: 860px){
  .api-grid{ grid-template-columns: 1fr; }
  .code-win{ transform:none; order:-1; }
}
@media (max-width: 560px){
  .api-stats{ grid-template-columns: 1fr 1fr; }
  .conn-grid{ grid-template-columns: 1fr; }
}
