/* ==========================================================================
   TEKSJM — professional.css
   Light, restrained corporate skin. Navy/steel-blue, brand-cohesive with the
   SJM family. Clean, trustworthy, minimal motion.
   ========================================================================== */

.theme-pro {
  --font-body: "Inter", system-ui, sans-serif;
  --font-head: "Plus Jakarta Sans", "Inter", sans-serif;

  --bg: #ffffff;
  --surface: #ffffff;
  --ink: #2b3344;
  --ink-strong: #0f2a4a;
  --ink-soft: #54627a;
  --line: #e6ecf4;

  --accent: #2e6fbf;
  --accent-deep: #1f4c84;
  --accent-ink: #0f2a4a;

  --badge-bg: #eaf2fc;
  --pill-bg: #eef4fc;
  --pill-ink: #1f4c84;
  --ghost-bg: #ffffff;
  --header-bg: rgba(255,255,255,.85);
  --header-line: rgba(15,42,74,.08);
  --focus-ring: rgba(46,111,191,.16);
  --shadow-btn: 0 10px 22px rgba(31,76,132,.22);
  --shadow-btn-hover: 0 14px 30px rgba(31,76,132,.3);

  --card-radius: 16px;
  --btn-radius: 10px;
  --footer-bg: #0c2240;
  --footer-ink: #aebfd6;
}

.accent-text { color: var(--accent); }

/* Focus-visible (a11y) */
.theme-pro a:focus-visible, .theme-pro button:focus-visible, .theme-pro .nav-toggle:focus-visible,
.theme-pro summary:focus-visible, .theme-pro .work-tile:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 6px;
}

/* ---- Section rhythm / tints ---- */
.problem { background: #f6f9fd; }
.savings { background: #f6f9fd; }
.solution { background: #fff; }

/* ---- Hero ---- */
.hero { padding-top: clamp(48px, 6vw, 84px); overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center; }
.hero-glow {
  position: absolute; top: -160px; right: -120px; width: 620px; height: 620px;
  background: radial-gradient(closest-side, rgba(46,111,191,.14), transparent 70%);
  pointer-events: none; z-index: 0;
}
.hero-copy { position: relative; z-index: 1; }
.hero-copy .lead { margin-top: 20px; }
.eyebrow svg { width: 16px; height: 16px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.hero-visual svg { width: 100%; max-width: 480px; margin-inline: auto; filter: drop-shadow(0 24px 40px rgba(15,42,74,.1)); }
.hero-visual .spoke { transform-box: fill-box; transform-origin: center; animation: spokeFloat 5s ease-in-out infinite; }
.hero-visual .spoke:nth-of-type(2) { animation-delay: .8s; }
.hero-visual .spoke:nth-of-type(3) { animation-delay: 1.6s; }
@keyframes spokeFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
@media (prefers-reduced-motion: reduce) { .hero-visual .spoke { animation: none; } }

/* ---- Trust strip ---- */
.strip { border-block: 1px solid var(--line); background: #fbfcfe; }
.strip-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 10px 18px; color: var(--ink-soft); font-size: .96rem; }
.strip-row span { font-weight: 600; color: var(--ink-soft); }
.strip-row b { color: var(--ink-strong); font-weight: 700; }
.strip-row i { color: #c2cede; font-style: normal; }

/* ---- Problem ---- */
.sec-head { margin-bottom: 48px; }
.sec-head .eyebrow { margin-bottom: 14px; }
.sec-head .lead { margin-top: 14px; }
.vs-before { display: flex; align-items: center; justify-content: center; gap: clamp(8px, 3vw, 40px); flex-wrap: wrap; margin-bottom: 30px; }
.vendor-node { text-align: center; }
.vendor-node .vn-ico {
  width: 96px; height: 96px; border-radius: 22px; display: grid; place-items: center;
  font-size: 42px; background: #fff; border: 1.5px dashed #c6d5e8; margin-bottom: 12px;
  box-shadow: 0 10px 24px rgba(15,42,74,.06);
}
.vendor-node span { font-weight: 700; color: var(--ink-strong); }
.vs-gap { width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center; background: #fdecec; color: #d4493f; font-weight: 800; font-size: 1.1rem; }
.problem-tags { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }
.tag-bad { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; border-radius: 999px; background: #fff; border: 1px solid #f0d6d3; color: #b4453c; font-weight: 600; font-size: .92rem; }
.tag-bad i { font-style: normal; }

/* ---- Solution ---- */
.solution-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 56px; align-items: center; }
.solution-visual svg { width: 100%; max-width: 440px; }
.check-list { margin-top: 24px; display: grid; gap: 14px; }
.check-list li { display: flex; align-items: center; gap: 12px; font-weight: 600; color: var(--ink-strong); }
.check-list svg { width: 22px; height: 22px; flex: none; color: #fff; background: var(--accent); border-radius: 50%; padding: 4px; }

/* ---- Services ---- */
.services-grid { grid-template-columns: repeat(3, 1fr); }
.service-card:hover { transform: translateY(-6px); box-shadow: 0 22px 44px rgba(15,42,74,.1); border-color: #cfe0f4; }
.service-card p { color: var(--ink-soft); margin-top: 4px; }
.card-link { display: inline-flex; align-items: center; gap: 7px; margin-top: 18px; font-weight: 700; color: var(--accent); }
.card-link span { transition: transform .2s; }
.service-card:hover .card-link span { transform: translateX(4px); }

/* ---- Savings / compare ---- */
.compare { display: grid; grid-template-columns: 1fr auto 1fr; gap: 18px; align-items: stretch; margin-bottom: 44px; }
.compare-col { background: #fff; border-radius: 18px; padding: 28px; border: 1px solid var(--line); }
.compare-col header { margin-bottom: 18px; }
.ct-label { font-weight: 800; font-size: 1.05rem; font-family: var(--font-head); color: var(--ink-strong); }
.compare-col ul { display: grid; gap: 13px; }
.compare-col li { display: flex; align-items: flex-start; gap: 11px; color: var(--ink-soft); font-weight: 500; }
.compare-col li i { font-style: normal; font-weight: 800; flex: none; width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; font-size: .8rem; }
.compare-bad { border-top: 3px solid #e2867d; }
.compare-bad li i { background: #fdecea; color: #cf4a3e; }
.compare-good { border-top: 3px solid #2e6fbf; background: #f9fcff; }
.compare-good li i { background: #e4f1ff; color: #1f6fc4; }
.compare-vs { align-self: center; font-family: var(--font-head); font-weight: 800; color: #fff; background: var(--accent); width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; font-size: .92rem; box-shadow: 0 10px 24px rgba(31,76,132,.3); }

/* ---- Contact ---- */
.contact { background: linear-gradient(180deg,#f6f9fd 0%, #eef4fc 100%); }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 52px; align-items: start; }
.contact-copy .lead { margin-top: 16px; }
.contact-points { margin-top: 28px; display: grid; gap: 16px; }
.contact-points li { display: flex; align-items: center; gap: 14px; }
.cp-ico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: #fff; border: 1px solid var(--line); font-size: 20px; }
.contact-points b { display: block; color: var(--ink-strong); font-size: .96rem; }
.contact-points span { color: var(--ink-soft); font-size: .92rem; }
.contact-card { box-shadow: 0 26px 60px rgba(15,42,74,.12); }
.form-submit { width: 100%; justify-content: center; margin-top: 20px; }
.form-note { margin-top: 14px; font-size: .85rem; color: #6b7892; text-align: center; }

/* ---- Footer ---- */
.brand--footer { margin-bottom: 16px; }
.brand--footer .logo-text { color: #fff; }
.brand--footer .logo-text b { color: #5aa0e6; }
.footer-about { color: #9fb2cc; font-size: .92rem; max-width: 34ch; }

/* ---- Solutions (industries) ---- */
.solutions { background: #fff; }
.sol-grid { grid-template-columns: repeat(4,1fr); }
.sol-card { text-align: left; }
.sol-card:hover { transform: translateY(-5px); box-shadow: 0 20px 40px rgba(15,42,74,.08); border-color: #cfe0f4; }
.sol-card .si { font-size: 30px; margin-bottom: 16px; display: block; }
.sol-card h4 { font-family: var(--font-head); font-size: 1.08rem; color: var(--ink-strong); margin-bottom: 6px; }
.sol-card p { color: var(--ink-soft); font-size: .9rem; }

/* ---- Work / portfolio ---- */
.work { background: #f6f9fd; }
.work-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 18px; }
.work-tile { position: relative; border-radius: 18px; overflow: hidden; min-height: 210px; display: flex; flex-direction: column; justify-content: flex-end; padding: 24px; color: #fff; border: 1px solid rgba(15,42,74,.06); transition: transform .35s, box-shadow .35s; }
.work-tile::before { content: ""; position: absolute; inset: 0; z-index: 0; }
.work-tile:nth-child(1)::before { background: radial-gradient(90% 80% at 22% 18%, #2e6fbf 0%, #0c2240 72%); }
.work-tile:nth-child(2)::before { background: radial-gradient(90% 80% at 78% 16%, #3b82c9 0%, #163a63 72%); }
.work-tile:nth-child(3)::before { background: radial-gradient(90% 80% at 30% 85%, #4f93cf 0%, #1f4c84 72%); }
.work-tile:nth-child(4)::before { background: radial-gradient(90% 80% at 75% 80%, #1f93b0 0%, #0c3547 72%); }
.work-tile:nth-child(5)::before { background: radial-gradient(90% 80% at 25% 20%, #2e6fbf 0%, #0c2240 72%); }
.work-tile::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(110deg, transparent 35%, rgba(255,255,255,.1) 50%, transparent 65%); transform: translateX(-120%); transition: transform .9s cubic-bezier(.2,.7,.2,1); }
.work-tile:hover::after { transform: translateX(120%); }
.work-tile > * { position: relative; z-index: 1; }
.work-tile.w-lg { grid-column: span 4; } .work-tile.w-sm { grid-column: span 2; }
.work-tile:hover { transform: translateY(-6px); box-shadow: 0 24px 48px rgba(15,42,74,.22); }
.work-tile .wt-cat { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: #9ec4ef; font-weight: 700; }
.work-tile h4 { font-family: var(--font-head); color: #fff; font-size: 1.15rem; margin-top: 6px; }
.work-tile .wt-play { position: absolute; top: 20px; right: 20px; z-index: 2; width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.3); color: #fff; backdrop-filter: blur(4px); }
.work-tile .wt-play svg { width: 18px; height: 18px; }

/* ---- Insights / blog ---- */
.insights { background: #fff; }
.insights-grid { grid-template-columns: repeat(3,1fr); }
.post-card { padding: 0; overflow: hidden; }
.post-card:hover { transform: translateY(-6px); box-shadow: 0 22px 44px rgba(15,42,74,.1); border-color: #cfe0f4; }
.post-card .pc-top { height: 140px; display: flex; align-items: flex-end; padding: 18px; }
.pc-web { background: linear-gradient(150deg,#2e6fbf,#163a63); }
.pc-mkt { background: linear-gradient(150deg,#16708a,#0c3547); }
.pc-film { background: linear-gradient(150deg,#1f4c84,#0c2240); }
.post-card .pc-tag { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #1f4c84; background: #fff; padding: 5px 11px; border-radius: 999px; }
.post-card .pc-body { padding: 22px 24px 26px; }
.post-card h4 { font-family: var(--font-head); color: var(--ink-strong); font-size: 1.1rem; line-height: 1.28; }
.post-card p { color: var(--ink-soft); font-size: .9rem; margin-top: 10px; }
.post-card .pc-meta { margin-top: 16px; font-size: .82rem; color: #8a97ad; display: flex; gap: 10px; }

/* ---- FAQ ---- */
.faq-sec { background: #f6f9fd; }
.faq { max-width: 800px; margin-inline: auto; display: grid; gap: 14px; }
.faq-item { padding: 0; }
.faq-item summary { list-style: none; cursor: pointer; padding: 22px 26px; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-family: var(--font-head); font-weight: 700; font-size: 1.05rem; color: var(--ink-strong); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .fq-ico { flex: none; width: 28px; height: 28px; border-radius: 50%; background: #eaf2fc; display: grid; place-items: center; color: var(--accent); transition: transform .3s; font-size: 1.1rem; }
.faq-item[open] summary .fq-ico { transform: rotate(45deg); }
.faq-item .fq-a { padding: 0 26px 24px; color: var(--ink-soft); font-size: .96rem; line-height: 1.65; }

/* ---- Responsive ---- */
@media (max-width: 1000px) { .sol-grid { grid-template-columns: 1fr 1fr; } .insights-grid { grid-template-columns: 1fr; } }
@media (max-width: 940px) {
  .hero-grid, .solution-grid, .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-visual { order: -1; }
  .solution-visual { max-width: 380px; margin-inline: auto; }
  .services-grid { grid-template-columns: 1fr; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .work-tile.w-lg, .work-tile.w-sm { grid-column: span 2; }
}
@media (max-width: 760px) {
  .compare { grid-template-columns: 1fr; }
  .compare-vs { padding: 4px; }
  .sol-grid { grid-template-columns: 1fr; }
  .work-grid { grid-template-columns: 1fr; }
  .work-tile.w-lg, .work-tile.w-sm { grid-column: span 1; }
}
