/* ═══════════════════════════════════════════════════════════════
   WebGet — Blue palette override (replaces purple/indigo accents)
   Loaded AFTER style.css so it wins on cascade.
   ═══════════════════════════════════════════════════════════════ */

:root {
  /* WebGet brand blues */
  --acc: #1e40af;        /* navy blue 800 — primary accent */
  --acc2: #3b82f6;       /* blue 500 — mid accent */
  --acc-light: #60a5fa;  /* blue 400 — light accent */
  --accbg: #dbeafe;      /* blue 100 — accent background */
  --accbg2: #eff6ff;     /* blue 50 — even lighter */
}

/* ─── Buttons ─────────────────────────────────────────────────── */
.btn-primary {
  background: #1e40af !important;
  color: #fff !important;
  border-color: transparent;
}
.btn-primary:hover {
  background: #1e3a8a !important;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(30,64,175,.32);
}

/* Ensure ALL .btn get the pls-btn hover behavior baseline */
.btn {
  transition: transform .28s cubic-bezier(.2,.7,.2,1), box-shadow .28s, background .2s, color .2s;
  position: relative;
  overflow: hidden;
}
/* Light variant: hover gives a subtle blue tint */
.btn-light:hover {
  border-color: #1e40af !important;
  color: #1e40af !important;
  background: #eff6ff !important;
}

/* Pls-btn icon slide on hover (already exists in style.css, just ensure visible everywhere) */
.pls-btn .pls-ico-wrap { position: relative; display: inline-flex; width: 16px; height: 16px; overflow: hidden; }
.pls-btn .pls-ico-wrap .ico-1,
.pls-btn .pls-ico-wrap .ico-2 {
  position: absolute; inset: 0; width: 16px; height: 16px;
  transition: transform .35s cubic-bezier(.2,.7,.2,1);
}
.pls-btn .pls-ico-wrap .ico-2 { transform: translateX(-110%); }
.pls-btn:hover .pls-ico-wrap .ico-1 { transform: translateX(110%); }
.pls-btn:hover .pls-ico-wrap .ico-2 { transform: translateX(0); }

/* ─── Gradient text — WebGet blue version (fixed cascade) ───── */
.gradient-text,
.page-hero h1 .gradient-text,
h1 .gradient-text,
h2 .gradient-text {
  background-image: linear-gradient(135deg, #1e3a8a, #3b82f6, #60a5fa, #1e3a8a) !important;
  background-size: 300% 300% !important;
  background-repeat: no-repeat !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  color: transparent !important;
  animation: gradientShift 4s ease-in-out infinite !important;
  display: inline-block;
}
/* ─── Tags / pills ────────────────────────────────────────────── */
.tag {
  color: #1e40af !important;
  background: #dbeafe !important;
  border-color: #bfdbfe !important;
}

/* ─── Accent links ────────────────────────────────────────────── */
a[style*="color:var(--acc)"],
.svc-cta { color: #1e40af !important; }

/* ─── Service cards highlighted ───────────────────────────────── */
.svc-card.pop, .pc2.feat {
  border-color: #1e40af !important;
}
.pc2.feat { box-shadow: 0 12px 36px rgba(30,64,175,.18) !important; }
.pc2-badge {
  color: #fff !important;
  background: #1e40af !important;
}

/* ─── Hero floating badge accent backgrounds ──────────────────── */
.hero-float[style*="border-color:rgba(79,70,229"] { border-color: rgba(30,64,175,.15) !important; }
.hero-float .hf-ico[style*="background:#eef2ff"] { background: #dbeafe !important; }
.hero-float .hf-ico svg[stroke="#4f46e5"] { stroke: #1e40af !important; }

/* ─── Accent-box (hero highlight) ─────────────────────────────── */
.accent-box {
  background: linear-gradient(135deg, #1e3a8a 0%, #3b82f6 100%) !important;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
}

/* ─── pc2 check icons (pricing list) ──────────────────────────── */
.pc2-check { background: #dbeafe !important; }
.pc2-check svg { stroke: #1e40af !important; }

/* ─── Why2-card "us" (the WebGet column in comparison) ────────── */
.why2-card.us { border-color: #1e40af !important; }
.why2-card.us .why2-amt { color: #1e40af !important; }

/* ─── Compare table our column ────────────────────────────────── */
.cmp2-table th.us, .cmp2-table td.us {
  background: rgba(30,64,175,.04) !important;
}
.cmp2-yes { color: #1e40af !important; }

/* ─── Hero blobs (background ambient color) ───────────────────── */
.hero-blob.hb1, .hero-blob.hb2, .hero-blob.hb3 {
  background: radial-gradient(circle, rgba(59,130,246,.18) 0%, rgba(59,130,246,0) 70%) !important;
}

/* ─── Active focus rings ──────────────────────────────────────── */
:where(button, a, input, textarea, select):focus-visible {
  outline-color: #1e40af !important;
}

/* ─── FAQ item open state ─────────────────────────────────────── */
.faq-item.open .faq-q { color: #1e40af !important; }

/* ─── Surm-box gradient (site sur mesure block) ───────────────── */
.surm-box {
  background: linear-gradient(135deg, #0c1424 0%, #1e3a8a 60%, #3b82f6 100%) !important;
}

/* ─── Logo gradient: blueify ─────────────────────────────────── */
/* Note: SVG linearGradient stops are inline in HTML. We do CSS-level filter trick on the wrap for subtle blueing if needed. */


/* ═══ Harmonized hero h1 sizing across all pages ════════════════ */
.page-hero h1,
.sec.page-hero h1 {
  font-size: clamp(2.8rem, 5.5vw, 4.2rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -.03em !important;
  font-weight: 800 !important;
  font-family: 'Plus Jakarta Sans', Inter, sans-serif !important;
}

/* ═══ Sur-mesure: card grid for "Ce qui est inclus" ═══════════ */
.sm-feats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 40px;
}
@media (max-width: 880px) { .sm-feats-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .sm-feats-grid { grid-template-columns: 1fr; } }
.sm-feat {
  background: #fff;
  border: 1px solid var(--bd);
  border-radius: 16px;
  padding: 24px 22px;
  transition: all .3s cubic-bezier(.2,.7,.2,1);
}
.sm-feat:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(30,64,175,.08);
  border-color: #1e40af;
}
.sm-feat-ico {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: #dbeafe;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.sm-feat-ico svg {
  width: 22px; height: 22px;
  stroke: #1e40af;
}
.sm-feat h4 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--tx);
  font-family: 'Plus Jakarta Sans', Inter, sans-serif;
  letter-spacing: -.01em;
  margin-bottom: 6px;
}
.sm-feat p {
  font-size: .85rem;
  color: var(--tx2);
  line-height: 1.55;
  margin: 0;
}

/* ═══ Sur-mesure 4 étapes equal layout ════════════════════════ */
@media (max-width: 880px) {
  section .svc-grid[style*="repeat(4,1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 520px) {
  section .svc-grid[style*="repeat(4,1fr)"] {
    grid-template-columns: 1fr !important;
  }
}


/* ═══ Sur-mesure: numbered horizontal rows for "Ce qui est inclus" ═══ */
.inclus-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 32px;
  margin-top: 48px;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 760px) { .inclus-grid { grid-template-columns: 1fr; gap: 10px; } }

.inclus-row {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 22px 24px;
  background: #fff;
  border: 1px solid var(--bd);
  border-radius: 14px;
  transition: all .3s cubic-bezier(.2,.7,.2,1);
}
.inclus-row:hover {
  border-color: #1e40af;
  box-shadow: 0 10px 28px rgba(30,64,175,.08);
  transform: translateY(-2px);
}
.inclus-num {
  font-family: 'Plus Jakarta Sans', Inter, sans-serif;
  font-weight: 800;
  font-size: 1.4rem;
  color: #1e40af;
  letter-spacing: -.02em;
  line-height: 1;
  min-width: 40px;
  padding-top: 2px;
  background: linear-gradient(135deg, #1e3a8a, #3b82f6, #60a5fa);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.inclus-content { flex-grow: 1; min-width: 0; }
.inclus-content h4 {
  font-family: 'Plus Jakarta Sans', Inter, sans-serif;
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--tx);
  margin: 0 0 6px 0;
}
.inclus-content p {
  font-size: .88rem;
  color: var(--tx2);
  line-height: 1.55;
  margin: 0;
}


/* ═══ Real integration logos (Simple Icons) ═══ */
.integ-logo-img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  margin: 0 auto 12px;
  display: block;
}

/* ═══ Stack-band: real logos ═══ */
.stack-band {
  background: #fafbff;
  border-top: 1px solid var(--bd);
  border-bottom: 1px solid var(--bd);
}
.stack-band .label {
  text-align: center;
  font-size: .74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--tx3);
  margin-bottom: 28px;
}
.stack-row {
  display: flex;
  justify-content: center;
  gap: 36px;
  flex-wrap: wrap;
  align-items: center;
}
.stack-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: #fff;
  border: 1px solid var(--bd);
  border-radius: 12px;
  transition: all .25s ease;
  cursor: default;
}
.stack-logo:hover {
  border-color: #1e40af;
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(30,64,175,.08);
}
.stack-logo img {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex-shrink: 0;
}
.stack-logo span {
  font-size: .88rem;
  font-weight: 600;
  color: var(--tx);
  font-family: 'Plus Jakarta Sans', Inter, sans-serif;
  letter-spacing: -.01em;
}
@media (max-width: 640px) {
  .stack-row { gap: 12px; }
  .stack-logo { padding: 8px 12px; }
  .stack-logo span { font-size: .78rem; }
  .stack-logo img { width: 18px; height: 18px; }
}

/* ═══ Agent showcase 3x3 grid (used on /agents and homepage) ═══ */
.ag-show { padding: 90px 0; background: #fafbff; }
.ag-show-head { text-align: center; max-width: 780px; margin: 0 auto 56px; }
.ag-show-head h2 {
  font-family: 'Plus Jakarta Sans', Inter, sans-serif;
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.1;
  color: var(--tx);
  margin-bottom: 14px;
}
.ag-show-head p {
  font-size: 1.05rem;
  color: var(--tx2);
  line-height: 1.6;
}
.ag-show-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 1180px;
  margin: 0 auto;
}
@media (max-width: 880px) { .ag-show-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .ag-show-grid { grid-template-columns: 1fr; } }
.ag-show-card {
  background: #fff;
  border: 1px solid var(--bd);
  border-radius: 20px;
  padding: 24px;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
  position: relative;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  display: block;
}
.ag-show-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(20,30,80,.1);
  border-color: #1e40af;
}
.ag-show-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: #dbeafe;
  overflow: hidden;
  border: 3px solid #fff;
  box-shadow: 0 4px 12px rgba(30,64,175,.18);
  margin-bottom: 14px;
}
.ag-show-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ag-show-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--tx);
  letter-spacing: -.02em;
  line-height: 1.1;
  margin-bottom: 4px;
}
.ag-show-role {
  font-size: .74rem;
  font-weight: 700;
  color: #1e40af;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 14px;
}
.ag-show-desc {
  font-size: .88rem;
  color: var(--tx2);
  line-height: 1.55;
  margin-bottom: 14px;
  min-height: 64px;
}
.ag-show-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .82rem;
  font-weight: 700;
  color: #1e40af;
  text-decoration: none;
}
.ag-show-link svg {
  width: 14px;
  height: 14px;
  transition: transform .2s;
}
.ag-show-card:hover .ag-show-link svg {
  transform: translateX(4px);
}

/* ═══════════════════════════════════════════════════════════════
   LIMOVA-INSPIRED POLISH — Light theme, WebGet blue
   ═══════════════════════════════════════════════════════════════ */

/* ─── Refined card style (softer shadows, less border) ───────── */
.svc-card, .pc2, .ag-show-card, .ag-card, .integ-card, .ob-step,
.price-sum-card, .sm-feat, .inclus-row, .fact-card, .why2-card {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.04) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.02), 0 4px 16px rgba(20,30,80,0.04) !important;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s !important;
}
.svc-card:hover, .pc2:hover, .ag-show-card:hover, .ag-card:hover,
.integ-card:hover, .ob-step:hover, .price-sum-card:hover, .sm-feat:hover,
.inclus-row:hover, .fact-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 4px 12px rgba(30,64,175,0.06), 0 16px 40px rgba(20,30,80,0.08) !important;
  border-color: rgba(30,64,175,0.18) !important;
}

/* Featured/highlighted cards keep stronger accent */
.pc2.feat, .price-sum-card.feat {
  border: 2px solid #1e40af !important;
  box-shadow: 0 8px 24px rgba(30,64,175,0.12), 0 24px 60px rgba(30,64,175,0.08) !important;
}

/* ─── Section background alternation (white / off-white rhythm) ─ */
.sec:nth-of-type(odd) { background: #ffffff; }
.sec:nth-of-type(even) { background: #fafbff; }
.sec.sec-alt { background: #fafbff !important; }

/* ─── Refined buttons: rounded 10-12px, generous padding ─────── */
.btn {
  border-radius: 12px !important;
  font-weight: 600 !important;
  letter-spacing: -.005em !important;
}
.btn-lg {
  padding: 14px 28px !important;
  font-size: .94rem !important;
}
.btn-primary {
  background: #1e40af !important;
  color: #fff !important;
  box-shadow: 0 2px 0 rgba(0,0,0,0.06), 0 8px 24px rgba(30,64,175,0.18) !important;
}
.btn-primary:hover {
  background: #1e3a8a !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 2px 0 rgba(0,0,0,0.08), 0 14px 32px rgba(30,64,175,0.28) !important;
}
.btn-light {
  background: #fff !important;
  color: var(--tx) !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04) !important;
}
.btn-light:hover {
  border-color: #1e40af !important;
  color: #1e40af !important;
  background: #fff !important;
  box-shadow: 0 4px 14px rgba(30,64,175,0.12) !important;
  transform: translateY(-2px) !important;
}

/* ─── Section spacing rhythm (airier) ─────────────────────────── */
.sec { padding: 80px 0 !important; }
@media (min-width: 1024px) { .sec { padding: 100px 0 !important; } }

/* ─── Tags / pills refined ────────────────────────────────────── */
.tag {
  background: #eff6ff !important;
  color: #1e40af !important;
  border: 1px solid rgba(30,64,175,0.12) !important;
  font-weight: 600 !important;
  font-size: .72rem !important;
  padding: 7px 14px !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* ─── Decorative blurred orbs in sections (signature Limova) ─── */
.sec.has-orb {
  position: relative;
  overflow: hidden;
}
.sec.has-orb::before {
  content: "";
  position: absolute;
  top: -20%;
  left: -10%;
  width: 480px;
  height: 480px;
  background: radial-gradient(circle, rgba(59,130,246,0.10) 0%, transparent 70%);
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}
.sec.has-orb::after {
  content: "";
  position: absolute;
  bottom: -20%;
  right: -10%;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(30,64,175,0.08) 0%, transparent 70%);
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}
.sec.has-orb .wrap { position: relative; z-index: 1; }

/* Typography polish */
.h2 {
  font-family: 'Plus Jakarta Sans', Inter, sans-serif !important;
  font-weight: 800 !important;
  letter-spacing: -.03em !important;
  line-height: 1.08 !important;
}
.h2-sub, .sec-head p {
  color: var(--tx2) !important;
  font-size: 1.05rem !important;
  line-height: 1.65 !important;
  font-weight: 400 !important;
}

/* Footer subtle refinement */
.footer { border-top: 1px solid rgba(0,0,0,0.06); background: #fafbff; }
