/* =====================================================
   Product Data Scrape — MASTER SHARED STYLESHEET
   Single source of truth for ALL pages
   
   Save to: /assets/pds-styles.css
   Load in <head> of every page:
   <link rel="stylesheet" href="assets/pds-styles.css">
   ===================================================== */

/* === DESIGN TOKENS === */
:root {
  /* Neutrals */
  --paper: #f4f6fa;
  --paper-2: #e9edf4;
  --ink: #15181f;
  --ink-soft: #5b6172;
  --cream: #fff;
  --line: #d9dfe9;
  /* Brand */
  --accent: #2f6df6;
  --accent-d: #2156d4;
  --teal: #0e1a38;
  /* Semantic */
  --red: #e23b52;
  --amber: #d98a13;
  --green: #1f9d57;
  --orange: #ff6a3d;
  --purple: #a855f7;
  /* Industry accents */
  --c-beauty: #c54c8a;
  --c-toys: #f5a623;
  --c-sport: #00874c;
  --c-auto: #c9302c;
  --c-baby: #a3c5e8;
  --c-furn: #8b6f47;
  --c-pharma: #1f9d57;
  --c-appliance: #374151;
  --c-restaurant: #dc2626;
  --c-b2b: #1e40af;
  --c-pet: #f59e0b;
  --c-jewelry: #a855f7;
  --c-office: #3b82f6;
  --c-tools: #ea580c;
  --c-books: #7c3aed;
  --c-garden: #16a34a;
  /* Country accents */
  --c-uae: #00732f;
  --c-au: #012169;
  --c-ca: #d80621;
  --c-de: #dd0000;
  --c-sg: #ed2e38;
  /* Marketplace accents */
  --c-amazon: #ff9900;
  --c-walmart: #0071ce;
  --c-flipkart: #2874f0;
  --c-myntra: #ff3f6c;
  --c-meesho: #f43397;
  --c-blinkit: #f8cb46;
  --c-zepto: #7c3aed;
  --c-swiggy: #fc8019;
  /* Radius */
  --r: 14px;
  --r-sm: 9px;
  --r-lg: 18px;
}

/* === RESET === */
.solution-inner-main {
  /* === RESET === */
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    /* font-family: "Bricolage Grotesque", sans-serif; */
    line-height: 1.1;
    font-weight: 700;
    letter-spacing: -0.02em;
  }

  a {
    color: inherit;
    text-decoration: none;
  }

  img,
  svg {
    display: block;
    max-width: 100%;
  }

  button {
    /* font-family: inherit; */
    border: none;
    background: none;
    cursor: pointer;
  }

  input,
  textarea,
  select {
    /* font-family: inherit; */
    font-size: inherit;
  }

  /* === LAYOUT === */
  .wrap {
    max-width: 1550px;
    margin: 0 auto;
    padding: 0 32px;
  }

  section {
    position: relative;
  }

  .sec {
    padding: 74px 0;
  }

  .sec-head {
    max-width: 680px;
    margin-bottom: 40px;
  }

  .sec-head.center {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .sec-head h2 {
    font-size: clamp(27px, 3.1vw, 38px);
    margin: 12px 0;
  }

  .sec-head p {
    color: var(--ink-soft);
    font-size: 16px;
  }

  /* === TYPOGRAPHY === */
  .mono {
    /* font-family: "IBM Plex Mono", monospace; */
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 12px;
    font-weight: 500;
  }

  .eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    color: var(--accent);
    margin-bottom: 16px;
    /* font-family: "IBM Plex Mono"; */
    font-size: 12px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  .eyebrow::before {
    content: "";
    width: 24px;
    height: 1.5px;
    background: var(--accent);
  }

  .eyebrow.center {
    justify-content: center;
  }

  .eyebrow.center::after {
    content: "";
    width: 24px;
    height: 1.5px;
    background: var(--accent);
  }

  /* === BUTTONS === */
  .btn {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-weight: 600;
    font-size: 15px;
    padding: 14px 24px;
    border-radius: 999px;
    cursor: pointer;
    border: 1.5px solid var(--ink);
    transition: all 0.15s;
    background: transparent;
    color: var(--ink);
    text-decoration: none;
    /* font-family: "IBM Plex Sans"; */
    white-space: nowrap;
  }

  .btn:hover {
    background: var(--ink);
    color: var(--paper);
    transform: translateY(-2px);
  }

  .btn-primary {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
  }

  .btn-primary:hover {
    background: var(--accent-d);
    border-color: var(--accent-d);
    color: #fff;
  }

  .btn-light {
    background: #fff;
    border-color: #fff;
    color: var(--ink);
  }

  .btn-light:hover {
    transform: translateY(-2px);
  }

  .btn-ghost-light {
    background: transparent;
    color: #fff;
    border-color: #fff;
  }

  .btn-ghost-light:hover {
    background: #fff;
    color: var(--ink);
  }

  .btn .arr {
    transition: transform 0.15s;
  }

  .btn:hover .arr {
    transform: translateX(3px);
  }

  /* === HERO === */
  .hero {
    padding: 36px 0 60px;
    border-bottom: 1px solid var(--line);
    background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
  }

  .hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 48px;
    align-items: center;
  }

  .hero h1 {
    font-size: clamp(33px, 4.2vw, 50px);
  }

  .hero h1 .hl {
    position: relative;
    /* white-space: nowrap; */
  }

  .hero h1 .hl::after {
    content: "";
    position: absolute;
    left: -2px;
    right: -2px;
    bottom: 4px;
    height: 10px;
    background: var(--accent);
    opacity: 0.22;
    z-index: -1;
  }

  .hero .sub {
    font-size: 17.5px;
    color: var(--ink-soft);
    margin: 20px 0 26px;
    max-width: 520px;
  }

  .hero-ctas {
    display: flex;
    gap: 13px;
    flex-wrap: wrap;
  }

  .trustline {
    margin-top: 18px;
    font-size: 13px;
    color: var(--ink-soft);
  }

  .trustline b {
    color: var(--ink);
    font-weight: 600;
  }

  /* === HERO VISUAL CARD === */
  .viz-card {
    background: var(--cream);
    border: 1px solid var(--line);
    border-radius: var(--r);
    box-shadow: 0 24px 50px rgba(21, 24, 31, 0.13);
    overflow: hidden;
  }

  .viz-bar {
    background: var(--ink);
    padding: 13px 18px;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .viz-bar .d {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #3a3f4d;
  }

  .viz-bar .t {
    margin-left: 8px;
    color: #cfd3db;
    /* font-family: "IBM Plex Mono"; */
    font-size: 11px;
    letter-spacing: 0.04em;
  }

  .viz-bar .b {
    margin-left: auto;
    background: var(--accent);
    color: #fff;
    /* font-family: "IBM Plex Mono"; */
    font-size: 9px;
    padding: 3px 8px;
    border-radius: 4px;
    font-weight: 700;
    letter-spacing: 0.04em;
  }

  .viz- {
    padding: 18px;
  }

  /* === STRIP === */
  .strip {
    background: var(--paper-2);
    border-bottom: 1px solid var(--line);
  }

  .strip-inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    padding: 26px 0;
  }

  .strip-card {
    background: var(--cream);
    border: 1px solid var(--line);
    border-radius: 11px;
    padding: 18px;
  }

  .strip-card .h {
    display: flex;
    align-items: center;
    gap: 9px;
    margin-bottom: 9px;
  }

  .strip-card .fl {
    font-size: 21px;
    width: 21px;
  }

  .strip-card .cn {
    /* font-family: "Bricolage Grotesque"; */
    font-weight: 700;
    font-size: 15.5px;
  }

  .strip-card .meta {
    font-size: 12px;
    color: var(--ink-soft);
    line-height: 1.7;
  }

  .strip-card .meta b {
    color: var(--ink);
    font-weight: 600;
  }

  /* === DATA GRID === */
  .data-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: var(--r);
    overflow: hidden;
  }

  .data-cell {
    background: var(--cream);
    padding: 26px 24px;
  }

  .data-cell .di {
    width: 36px;
    height: 36px;
    border-radius: 9px;
    background: var(--accent);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    /* font-family: "Bricolage Grotesque"; */
    font-weight: 800;
    font-size: 13px;
    margin-bottom: 10px;
  }

  .data-cell h4 {
    font-size: 16px;
    margin-bottom: 3px;
  }

  .data-cell p {
    font-size: 13.5px;
    color: var(--ink-soft);
    line-height: 1.6;
  }

  /* === SIGNALS === */
  .signals {
    background: var(--paper-2);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }

  .sig-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: var(--r);
    overflow: hidden;
  }

  .sig-cell {
    background: var(--cream);
    padding: 26px 28px;
    display: flex;
    gap: 16px;
  }

  .sig-cell .mk {
    /* font-family: "Bricolage Grotesque"; */
    font-weight: 800;
    font-size: 14px;
    color: #fff;
    /* background: var(--accent); */
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }

  .sig-cell h4 {
    font-size: 16.5px;
    margin-bottom: 5px;
  }

  .sig-cell p {
    font-size: 14px;
    color: var(--ink-soft);
  }

  .sig-cell a {
    color: var(--accent);
    font-weight: 600;
  }

  .sig-cell a:hover {
    text-decoration: underline;
  }

  /* === USE CASES === */
  .uc-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }

  .uc {
    background: var(--cream);
    border: 1px solid var(--line);
    border-radius: var(--r);
    padding: 24px 22px;
    border-left: 3px solid var(--accent);
  }

  .uc h4 {
    font-size: 16.5px;
    margin-bottom: 6px;
  }

  .uc p {
    font-size: 13.5px;
    color: var(--ink-soft);
  }

  /* === STEPS === */
  .steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
  }

  .step {
    padding: 28px 24px 0 0;
    border-top: 2px solid var(--ink);
  }

  .step:not(:last-child) {
    padding-right: 28px;
  }

  .step .n {
    /* font-family: "IBM Plex Mono"; */
    font-size: 12.5px;
    color: var(--accent);
    font-weight: 600;
    margin-bottom: 12px;
  }

  .step h4 {
    font-size: 17px;
    margin-bottom: 8px;
  }

  .step p {
    font-size: 14px;
    color: var(--ink-soft);
  }

  /* === FAQ === */
  .faq {
    background: var(--paper-2);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }

  .faq-list {
    max-width: 100%;
    margin: 0 auto;
  }

  .qa {
    border-bottom: 1px solid var(--line);
  }

  .qa:first-child {
    border-top: 1px solid var(--line);
  }

  .qa-q {
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
    padding: 22px 4px;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: center;
    /* font-family: "Bricolage Grotesque"; */
    font-weight: 700;
    font-size: 17px;
    color: var(--ink);
  }

  .qa-q .pm {
    font-size: 22px;
    color: var(--accent);
    transition: transform 0.2s;
    flex-shrink: 0;
  }

  .qa.open .pm {
    transform: rotate(45deg);
  }

  .qa-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.28s;
  }

  .qa-a p {
    padding: 0 4px 22px;
    color: var(--ink-soft);
    font-size: 15px;
    max-width: 100%;
  }

  /* === CTA BAND === */
  .ctaband {
    background: var(--accent);
    color: #fff;
    text-align: center;
    padding: 64px 0;
  }

  .ctaband h2 {
    font-size: clamp(28px, 3.4vw, 42px);
    color: #fff;
    max-width: 720px;
    margin: 0 auto 14px;
  }

  .ctaband p {
    color: #dde9ff;
    max-width: 560px;
    margin: 0 auto 22px;
    font-size: 16px;
  }

  .ctaband .ctas {
    display: flex;
    gap: 13px;
    justify-content: center;
    flex-wrap: wrap;
  }

  /* === RESOURCE CARDS (resources page) === */
  .res-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
    margin-bottom: 50px;
  }

  .res-card {
    background: var(--cream);
    border: 1px solid var(--line);
    border-radius: var(--r);
    padding: 30px;
    transition:
      transform 0.2s,
      box-shadow 0.2s,
      border-color 0.2s;
    display: flex;
    gap: 22px;
    align-items: flex-start;
    color: var(--ink);
  }

  .res-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(21, 24, 31, 0.08);
    border-color: var(--accent);
  }

  .res-card .ic {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    /* font-family: "Bricolage Grotesque"; */
    font-weight: 800;
    font-size: 21px;
    color: #fff;
  }

  .res-card .ic.blog {
    background: var(--accent);
  }

  .res-card .ic.case {
    background: var(--green);
  }

  .res-card .ic.research {
    background: var(--purple);
  }

  .res-card .ic.white {
    background: var(--ink);
  }

  .res-card .ic.info {
    background: var(--red);
  }

  .res-card .ic.video {
    background: var(--amber);
  }

  .res-card .ic.news {
    background: #00874c;
  }

  .res-card .ic.tech {
    background: #c9302c;
  }

  .res-card .ct {
    flex: 1;
    min-width: 0;
  }

  .res-card .lbl {
    /* font-family: "IBM Plex Mono"; */
    font-size: 10.5px;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 6px;
    display: block;
  }

  .res-card h3 {
    font-size: 21px;
    margin-bottom: 7px;
    line-height: 1.2;
    color: var(--ink);
  }

  .res-card p {
    font-size: 14px;
    color: var(--ink-soft);
    line-height: 1.55;
    margin-bottom: 11px;
  }

  .res-card .arr-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--accent);
    font-size: 13px;
    font-weight: 600;
    /* font-family: "IBM Plex Mono"; */
    text-transform: uppercase;
    letter-spacing: 0.04em;
    transition: gap 0.15s;
  }

  .res-card:hover .arr-link {
    gap: 10px;
  }

  /* === REVEAL ANIMATIONS === */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition:
      opacity 0.6s,
      transform 0.6s;
  }

  .reveal.in {
    opacity: 1;
    transform: none;
  }

  /* === RESPONSIVE === */
  @media (max-width: 1280px) {
    .pds-link {
      padding: 10px 11px;
      font-size: 14px;
    }

    .pds-items {
      gap: 2px;
    }
  }

  @media (max-width: 1180px) {
    .pds-link {
      padding: 10px 9px;
      font-size: 13.5px;
    }
  }

  @media (max-width: 1100px) {
    .pds-items {
      display: none;
    }

    .pds-mobile {
      display: flex;
    }

    .pds-cta .btn:not(.btn-primary) {
      display: none;
    }
  }

  @media (max-width: 960px) {
    .hero-grid {
      grid-template-columns: 1fr;
      gap: 34px;
    }

    .strip-inner,
    .data-grid,
    .uc-grid {
      grid-template-columns: 1fr 1fr;
    }

    .sig-grid {
      grid-template-columns: 1fr;
    }

    .steps {
      grid-template-columns: 1fr 1fr;
    }

    .foot-grid {
      grid-template-columns: 1fr 1fr;
    }

    .res-grid {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 600px) {
    .wrap {
      padding: 0 20px;
    }

    .strip-inner,
    .data-grid,
    .uc-grid,
    .steps {
      grid-template-columns: 1fr;
    }

    .sec {
      padding: 52px 0;
    }

    .pds-logo-text i {
      display: none;
    }

    .res-card {
      flex-direction: column;
    }

    .foot-grid {
      grid-template-columns: 1fr;
    }
  }

  /* ========================================== */

  /* ====================================================
   SOLUTION HUB PAGES (Commerce Intel + Quick Commerce)
   ==================================================== */

  .hero-hub {
    background: linear-gradient(180deg, #f4f6fa 0%, #fff 100%);
    padding: 60px 0 70px;
  }

  /* Trust row variants */
  .hero-hub .trust-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-top: 32px;
    padding-top: 22px;
    border-top: 1px solid var(--line);
  }
  .hero-hub .trust-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }
  .hero-hub .trust-item b {
    font-family: "IBM Plex Mono";
    font-size: 22px;
    color: var(--accent);
    font-weight: 600;
  }
  .hero-hub .trust-item span {
    font-family: "IBM Plex Mono";
    font-size: 11px;
    color: var(--ink-soft);
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }

  /* Hub Viz card */
  .hub-viz {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 16px 36px rgba(21, 24, 31, 0.1);
  }
  .hub-viz-bar {
    background: var(--ink);
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .hub-viz-bar .hv-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
  }
  .hub-viz-bar .hv-dot:nth-child(1) {
    background: #ef4444;
  }
  .hub-viz-bar .hv-dot:nth-child(2) {
    background: #f59e0b;
  }
  .hub-viz-bar .hv-dot:nth-child(3) {
    background: #10b981;
  }
  .hub-viz-bar .hv-title {
    font-family: "IBM Plex Mono";
    font-size: 12px;
    color: #fff;
    margin-left: 12px;
    flex: 1;
  }
  .hub-viz-body {
    padding: 14px;
  }
  .hv-row {
    display: grid;
    grid-template-columns: 70px 1fr auto;
    gap: 10px;
    align-items: center;
    padding: 10px 12px;
    border-bottom: 1px solid var(--line);
    font-family: "IBM Plex Mono";
    font-size: 12px;
  }
  .hv-row:last-of-type {
    border-bottom: none;
  }
  .hv-tag {
    display: inline-block;
    font-size: 9.5px;
    font-weight: 700;
    padding: 3px 7px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-align: center;
  }
  .hv-tag.price {
    background: #dbeafe;
    color: #1d4ed8;
  }
  .hv-tag.promo {
    background: #fef3c7;
    color: #92400e;
  }
  .hv-tag.stock {
    background: #fee2e2;
    color: #dc2626;
  }
  .hv-text {
    font-family: "IBM Plex Sans";
    font-size: 12.5px;
    color: var(--ink);
    font-weight: 500;
    line-height: 1.35;
  }
  .hv-time {
    font-size: 10.5px;
    color: var(--ink-soft);
  }
  .hv-foot {
    padding: 10px 12px;
    margin-top: 4px;
    border-top: 1px dashed var(--line);
    font-family: "IBM Plex Mono";
    font-size: 10.5px;
    color: var(--ink-soft);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  /* Hub card grid - sub-solutions */
  .sec-hub-grid .hub-card-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
  }
  .hub-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 26px 22px;
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--ink);
    transition: all 0.15s ease;
    position: relative;
  }
  .hub-card:hover {
    border-color: var(--accent);
    box-shadow: 0 12px 28px rgba(47, 109, 246, 0.1);
    transform: translateY(-3px);
  }
  .hub-card .hc-icon {
    font-size: 32px;
    margin-bottom: 14px;
    width: 35px;
  }
  .hub-card h4 {
    margin: 0 0 8px;
    font-size: 17px;
    line-height: 1.25;
    color: var(--ink);
  }
  .hub-card p {
    margin: 0 0 16px;
    font-size: 13.5px;
    color: var(--ink-soft);
    line-height: 1.5;
    flex: 1;
  }
  .hub-card .hc-link {
    font-family: "IBM Plex Mono";
    font-size: 12px;
    font-weight: 600;
    color: var(--accent);
    padding-top: 12px;
    border-top: 1px dashed var(--line);
  }

  /* Why Q-Commerce section */
  .sec-why-qc .why-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
  }
  .why-card {
    background: linear-gradient(135deg, #f4f6fa 0%, #e6ecf6 100%);
    border-radius: 14px;
    padding: 28px 24px;
    text-align: center;
  }
  .why-card .why-icon {
    margin: auto;
    font-size: 38px;
    margin-bottom: 12px;
    display: block;
    width: 35px;
  }
  .why-card h4 {
    margin: 0 0 10px;
    font-size: 17px;
  }
  .why-card p {
    margin: 0;
    font-size: 13.5px;
    color: var(--ink-soft);
    line-height: 1.55;
  }

  /* 3-step flow */
  .sec-hub-flow .flow-row {
    display: grid;
    grid-template-columns: 1fr 40px 1fr 40px 1fr;
    gap: 0;
    align-items: center;
    max-width: 100%;
    margin: 0 auto;
  }
  .flow-step {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 28px 24px;
  }
  .flow-step .fs-num {
    font-family: "IBM Plex Mono";
    font-size: 13px;
    font-weight: 700;
    color: var(--accent);
    background: var(--cream);
    padding: 4px 12px;
    border-radius: 5px;
    display: inline-block;
    margin-bottom: 14px;
  }
  .flow-step h4 {
    margin: 0 0 10px;
    font-size: 18px;
  }
  .flow-step p {
    margin: 0;
    font-size: 14px;
    color: var(--ink-soft);
    line-height: 1.55;
  }
  .flow-arr {
    font-size: 28px;
    color: var(--accent);
    text-align: center;
  }

  /* Mobile responsive for hub pages */
  @media (max-width: 1100px) {
    .sec-hub-grid .hub-card-grid {
      grid-template-columns: repeat(2, 1fr);
    }
    .sec-why-qc .why-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media (max-width: 960px) {
    .hero-hub .trust-row {
      grid-template-columns: repeat(2, 1fr);
    }
    .sec-hub-flow .flow-row {
      grid-template-columns: 1fr;
      gap: 14px;
    }
    .flow-arr {
      transform: rotate(90deg);
      padding: 6px 0;
    }
  }

  @media (max-width: 600px) {
    .sec-hub-grid .hub-card-grid {
      grid-template-columns: 1fr;
    }
    .sec-why-qc .why-grid {
      grid-template-columns: 1fr;
    }
    .hero-hub {
      padding: 40px 0 50px;
    }
    .hub-card {
      padding: 22px 20px;
    }
    .hv-row {
      grid-template-columns: 60px 1fr;
    }
    .hv-time {
      display: none;
    }
  }

  /* Grid */
  .icp-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }

  /* Card */
  .icp-card {
    background: #fff;
    padding: 28px;
    border-radius: 20px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    height: 100%;
  }

  .icp-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.12);
  }

  .icp-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(90deg, #2563eb, #06b6d4);
  }

  /* Role */
  .icp-role {
    font-size: 18px;
    font-weight: 700;
    color: #111827;
    margin-bottom: 12px;
    display: flex;
    gap: 10px;
  }
  .icp-role img {
    width: 35px;
  }

  /* Title */
  .icp-card h4 {
    font-size: 20px;
    color: #2563eb;
    margin-bottom: 12px;
    font-weight: 600;
  }

  /* Description */
  .icp-card p {
    color: #6b7280;
    line-height: 1.7;
    font-size: 15px;
    margin-bottom: 20px;
  }

  /* Tag */
  .icp-tag {
    display: inline-block;
    background: #eef2ff;
    color: #4338ca;
    padding: 10px 14px;
    border-radius: 30px;
    font-size: 13px;
    font-weight: 600;
  }

  /* =========================
   Responsive Design
========================= */

  /* Laptop */
  @media (max-width: 1440px) {
    .icp-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  /* Tablet */
  @media (max-width: 768px) {
    .icp-grid {
      grid-template-columns: 1fr;
      gap: 20px;
    }

    .icp-card {
      padding: 24px;
    }
  }

  /* Mobile */
  @media (max-width: 480px) {
    .sec-icp {
      padding: 60px 15px;
    }

    .icp-role {
      font-size: 17px;
    }

    .icp-card h4 {
      font-size: 18px;
    }
  }
}

/* ============ solution-competitor-price-monitoring.html (2 media queries) ============ */
:root {
  --paper: #f4f6fa;
  --paper-2: #e9edf4;
  --ink: #15181f;
  --ink-soft: #5b6172;
  --accent: #2f6df6;
  --teal: #0e1a38;
  --cream: #ffffff;
  --line: #d9dfe9;
  --red: #e23b52;
  --green: #1f9d57;
  --r: 14px;
}

.solution-inner-main .card-body {
  padding: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.solution-inner-main .pf-tile {
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.solution-inner-main .pf-tile .pf-h {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: space-between;
}
.solution-inner-main .pf-tile .pf-name {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 15px;
}
.solution-inner-main .pf-tile .pf-fl {
  font-size: 18px;
}
.solution-inner-main .pf-tile .pf-rg {
  font-family: "IBM Plex Mono";
  font-size: 10.5px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.solution-inner-main .pf-tile .pf-stats {
  display: flex;
  gap: 8px;
  margin-top: 4px;
}
.solution-inner-main .pf-tile .pf-stat {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 6px 8px;
  flex: 1;
}
.solution-inner-main .pf-tile .pf-stat .v {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 14px;
  color: var(--accent);
  line-height: 1;
}
.solution-inner-main .pf-tile .pf-stat .l {
  font-size: 10px;
  color: var(--ink-soft);
  margin-top: 2px;
  line-height: 1.3;
}
.solution-inner-main .sec-head.center {
  margin: 0 auto 40px;
  text-align: center;
}
.solution-inner-main .notebox {
  background: #fff5ec;
  border: 1px solid #ffdbb8;
  color: #7a3a1a;
  border-radius: 11px;
  padding: 14px 20px;
  margin-top: 30px;
  font-size: 13.5px;
  line-height: 1.65;
  display: flex;
  gap: 11px;
  align-items: flex-start;
}
.solution-inner-main .notebox .nb-ic {
  font-size: 18px;
  flex-shrink: 0;
  color: var(--amber);
}
.solution-inner-main .notebox b {
  color: #5c2a13;
}

.solution-inner-main .topbar {
  background: var(--ink);
  color: var(--paper);
  font-size: 13px;
  text-align: center;
  padding: 9px 16px;
}

.solution-inner-main .topbar b {
  color: var(--accent);
}

.solution-inner-main .nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
}

.solution-inner-main .logo {
  display: flex;
  align-items: center;
  gap: 10px;
}

.solution-inner-main .logo-cube {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.solution-inner-main .logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
  /* font-family: "Bricolage Grotesque"; */
}

.solution-inner-main .logo-text b {
  font-weight: 800;
  font-size: 17px;
  color: var(--accent);
}

.solution-inner-main .logo-text i {
  font-style: normal;
  font-weight: 600;
  font-size: 12.5px;
  color: var(--ink);
}

.solution-inner-main .nav-links {
  display: flex;
  gap: 26px;
  font-size: 15px;
  font-weight: 500;
}

.solution-inner-main .nav-links a {
  position: relative;
  padding: 4px 0;
}

.solution-inner-main .nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 2px;
  background: var(--accent);
  transition: width 0.2s;
}

.solution-inner-main .nav-links a:hover::after {
  width: 100%;
}

.solution-inner-main .nav-cta {
  display: flex;
  gap: 12px;
  align-items: center;
}

.solution-inner-main .sub {
  font-size: 17.5px;
  color: var(--ink-soft);
  margin: 20px 0 26px;
  max-width: 520px;
}

.solution-inner-main .dash {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: 0 24px 50px rgba(21, 24, 31, 0.13);
  overflow: hidden;
}

.solution-inner-main .dash-bar {
  background: var(--ink);
  padding: 13px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.solution-inner-main .dash-bar .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #3a3f4d;
}

.solution-inner-main .dash-bar .ttl {
  margin-left: 8px;
  color: #cfd3db;
  /* font-family: "IBM Plex Mono"; */
  font-size: 11px;
  letter-spacing: 0.04em;
}

.solution-inner-main .dash-tabs {
  display: flex;
  gap: 4px;
  padding: 14px 16px 0;
}

.solution-inner-main .dash-tab {
  font-size: 12px;
  font-weight: 600;
  padding: 7px 13px;
  border-radius: 8px 8px 0 0;
  background: var(--paper-2);
  color: var(--ink-soft);
}

.solution-inner-main .dash-tab.on {
  background: var(--accent);
  color: #fff;
}

.solution-inner-main .dash-body {
  padding: 14px 16px 18px;
}

.solution-inner-main .dash-row {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 6px;
  align-items: center;
  padding: 9px 6px;
  font-size: 12.5px;
  border-bottom: 1px solid var(--line);
}

.solution-inner-main .dash-row.head {
  /* font-family: "IBM Plex Mono"; */
  font-size: 9.5px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-soft);
  border-bottom: 1.5px solid var(--ink);
}

.solution-inner-main .dash-row .nm {
  font-weight: 600;
}

.solution-inner-main .dash-row .pr {
  font-weight: 600;
  text-align: right;
}

.solution-inner-main .down {
  color: var(--red);
}

.solution-inner-main .up {
  color: var(--green);
}

.solution-inner-main .alert {
  margin-top: 13px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fdeef0;
  border: 1px solid #f4c3cb;
  border-radius: 10px;
  padding: 11px 13px;
}

.solution-inner-main .alert .ico {
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: var(--red);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  flex-shrink: 0;
  font-size: 14px;
}

.solution-inner-main .alert .t {
  font-size: 12.5px;
}

.solution-inner-main .alert .t b {
  font-weight: 700;
}

.solution-inner-main .track-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.solution-inner-main .track {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 22px 20px;
  transition:
    transform 0.16s ease,
    border-color 0.16s ease;
}

.solution-inner-main .track:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
}

.solution-inner-main .track .ic {
  width: 38px;
  height: 38px;
  border-radius: 9px;
  background: #e5edfd;
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  /* font-family: "Bricolage Grotesque"; */
  font-weight: 800;
  font-size: 16px;
  margin-bottom: 13px;
}

.solution-inner-main .track h4 {
  font-size: 15.5px;
  margin-bottom: 5px;
}

.solution-inner-main .track p {
  font-size: 13px;
  color: var(--ink-soft);
}

.solution-inner-main .how {
  background: var(--paper-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.solution-inner-main .preview {
  background: var(--teal);
  color: var(--cream);
  border-top: 1px solid var(--ink);
}

.solution-inner-main .preview .sec-head h2 {
  color: var(--cream);
}

.solution-inner-main .preview .sec-head p {
  color: #aab3c9;
}

.solution-inner-main .preview .eyebrow {
  color: #8fb4ff;
}

.solution-inner-main .preview .eyebrow::before {
  background: #8fb4ff;
}

.solution-inner-main .pv {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 20px;
}

.solution-inner-main .pv-main,
.solution-inner-main .pv-side {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: var(--r);
  padding: 22px;
}

.solution-inner-main .pv-cap {
  /* font-family: "IBM Plex Mono"; */
  font-size: 10.5px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #8fb4ff;
  margin-bottom: 14px;
}

.solution-inner-main .pv-row {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 6px;
  font-size: 12.5px;
  padding: 9px 4px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.solution-inner-main .pv-row.head {
  /* font-family: "IBM Plex Mono"; */
  font-size: 9.5px;
  text-transform: uppercase;
  color: #8fb4ff;
}

.solution-inner-main .pv-row .r {
  text-align: right;
  font-weight: 600;
}

.solution-inner-main .chip-row {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.solution-inner-main .pvchip {
  font-size: 11px;
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  padding: 5px 11px;
  color: #dfe4ee;
}

.solution-inner-main .pvchip.on {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.solution-inner-main .trend {
  margin-top: 6px;
}

.solution-inner-main .pv-alert {
  background: rgba(226, 59, 82, 0.14);
  border: 1px solid rgba(226, 59, 82, 0.4);
  border-radius: 10px;
  padding: 12px;
  display: flex;
  gap: 9px;
  align-items: center;
  margin-top: 14px;
}

.solution-inner-main .pv-alert .d {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--red);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  flex-shrink: 0;
  font-size: 13px;
}

.solution-inner-main .pv-alert .t {
  font-size: 12px;
  color: #e9edf4;
}

.solution-inner-main .cty-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  /* background: var(--line);
  border: 1px solid var(--line); */
  border-radius: var(--r);
  overflow: hidden;
}

.cty-grid.cty-grid1 {
  background: unset;
  border: none;
}

.solution-inner-main .cty {
  background: var(--cream);
  padding: 24px 22px;
}

.solution-inner-main .cty .fl {
  font-size: 24px;
  width: 24px;
}

.solution-inner-main .cty h4 {
  font-size: 16px;
  margin: 9px 0 7px;
}

.solution-inner-main .cty p {
  font-size: 13px;
  color: var(--ink-soft);
}

.solution-inner-main .deliver {
  background: var(--paper-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.solution-inner-main .dl-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px;
  align-items: center;
}

.solution-inner-main .dl-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.solution-inner-main .dl-list li {
  display: flex;
  gap: 12px;
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 15px 17px;
}

.solution-inner-main .dl-list .mk {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  flex-shrink: 0;
  font-size: 13px;
}

.solution-inner-main .dl-list h4 {
  font-size: 15px;
  margin-bottom: 2px;
}

.solution-inner-main .dl-list p {
  font-size: 13px;
  color: var(--ink-soft);
}

.solution-inner-main .sample-alert {
  background: var(--ink);
  border-radius: var(--r);
  padding: 24px;
}

.solution-inner-main .sample-alert .cap {
  /* font-family: "IBM Plex Mono"; */
  font-size: 10.5px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #8fb4ff;
  margin-bottom: 14px;
}

.solution-inner-main .sa-card {
  background: #fff;
  border-radius: 10px;
  padding: 15px;
  margin-bottom: 11px;
}

.solution-inner-main .sa-card .top {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--ink-soft);
  margin-bottom: 7px;
}

.solution-inner-main .sa-card .msg {
  font-size: 13.5px;
}

.solution-inner-main .sa-card .msg b {
  font-weight: 700;
}

.solution-inner-main .sa-card .msg .down {
  color: var(--red);
  font-weight: 700;
}

.solution-inner-main .ben-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
}

.solution-inner-main .ben {
  background: var(--cream);
  padding: 26px 24px;
}

.solution-inner-main .ben .n {
  /* font-family: "Bricolage Grotesque"; */
  font-weight: 800;
  color: var(--accent);
  font-size: 15px;
  margin-bottom: 9px;
}

.solution-inner-main .ben h4 {
  font-size: 16px;
  margin-bottom: 6px;
}

.solution-inner-main .ben p {
  font-size: 13.5px;
  color: var(--ink-soft);
}

.solution-inner-main .cs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.solution-inner-main .cs {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 26px 24px;
  transition:
    transform 0.16s ease,
    border-color 0.16s ease;
}

.solution-inner-main .cs:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
}

.solution-inner-main .cs .tag {
  /* font-family: "IBM Plex Mono"; */
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent);
  font-weight: 600;
}

.solution-inner-main .cs .big {
  /* font-family: "Bricolage Grotesque"; */
  font-size: 38px;
  font-weight: 800;
  color: var(--ink);
  margin: 8px 0 4px;
  line-height: 1;
}

.solution-inner-main .cs h4 {
  font-size: 15px;
  margin-bottom: 7px;
}

.solution-inner-main .cs p {
  font-size: 13px;
  color: var(--ink-soft);
}

.solution-inner-main .qa.open .pm {
  transform: rotate(45deg);
}

.solution-inner-main .reveal.in {
  opacity: 1;
  transform: none;
}

@media (max-width: 960px) {
  .solution-inner-main .hero-grid,
  .solution-inner-main .pv,
  .solution-inner-main .dl-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .solution-inner-main .strip-inner,
  .solution-inner-main .track-grid,
  .solution-inner-main .cty-grid {
    grid-template-columns: 1fr 1fr;
  }

  .solution-inner-main .uc-grid,
  .solution-inner-main .ben-grid,
  .solution-inner-main .cs-grid {
    grid-template-columns: 1fr 1fr;
  }

  .solution-inner-main .nav-links,
  .solution-inner-main .nav-cta .btn-ghost {
    display: none;
  }
}

@media (max-width: 600px) {
  .solution-inner-main .strip-inner,
  .solution-inner-main .track-grid,
  .solution-inner-main .cty-grid,
  .solution-inner-main .uc-grid,
  .solution-inner-main .ben-grid,
  .solution-inner-main .cs-grid {
    grid-template-columns: 1fr;
  }

  .solution-inner-main .dash-row,
  .solution-inner-main .pv-row {
    grid-template-columns: 1.4fr 1fr 1fr;
  }

  .solution-inner-main .dash-row .c4,
  .solution-inner-main .pv-row .c4 {
    display: none;
  }
}

/* ============ solution-hyperlocal-pricing-intelligence.php ============ */

/* === EMERGING SOLUTIONS PAGES (shared rt-card style) === */

.solution-inner-main .trend-card .row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 11px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  margin-bottom: 6px;
  align-items: center;
  font-family: "IBM Plex Mono";
}

.solution-inner-main .trend-card .row.hot {
  background: #fef5e7;
  border-color: #fcd9a3;
}

.solution-inner-main .trend-card .row.cold {
  opacity: 0.6;
}

.solution-inner-main .trend-card .nm {
  font-family: "IBM Plex Sans";
  font-weight: 600;
  font-size: 12.5px;
  color: var(--ink);
}

.solution-inner-main .trend-card .nm small {
  display: block;
  font-size: 10.5px;
  color: var(--ink-soft);
  font-weight: 400;
  margin-top: 1px;
  font-family: "IBM Plex Sans";
}

.solution-inner-main .trend-card .pct {
  font-size: 13px;
  font-weight: 800;
  color: var(--green);
  text-align: right;
}

.solution-inner-main .trend-card .pct.down {
  color: var(--red);
}

.solution-inner-main .trend-card .arrow {
  font-family: "Bricolage Grotesque";
  font-size: 18px;
  font-weight: 800;
  color: var(--green);
}

.solution-inner-main .trend-card .arrow.down {
  color: var(--red);
  transform: rotate(180deg);
}

.solution-inner-main .viz-body {
  padding: 18px;
}

.solution-inner-main .rt-card .rt-row {
  display: grid;
  grid-template-columns: 1.4fr 1.4fr 0.9fr;
  gap: 11px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  margin-bottom: 6px;
  align-items: center;
  font-family: "IBM Plex Mono";
}

.solution-inner-main .rt-card .rt-row.hot {
  background: #fef5e7;
  border-color: #fcd9a3;
}

.solution-inner-main .rt-card .rt-row.down {
  background: #fef2f2;
  border-color: #fca5a5;
}

.solution-inner-main .rt-card .rt-nm {
  font-family: "IBM Plex Sans";
  font-weight: 600;
  font-size: 12.5px;
  color: var(--ink);
}

.solution-inner-main .rt-card .rt-mid {
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .rt-card .rt-end {
  font-size: 12px;
  font-weight: 800;
  color: var(--green);
  text-align: right;
}

.solution-inner-main .rt-card .rt-row.down .rt-end {
  color: var(--red);
}

.solution-inner-main .rt-card .rt-legend {
  margin-top: 10px;
  font-family: "IBM Plex Mono";
  font-size: 10px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: center;
}

.solution-inner-main .heatmap-h {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 13px;
  font-size: 11.5px;
  color: var(--ink-soft);
}

.solution-inner-main .heatmap-h b {
  color: var(--ink);
}

.solution-inner-main .grid-hm {
  display: grid;
  grid-template-columns: 80px repeat(5, 1fr);
  gap: 5px;
  font-size: 10.5px;
}

.solution-inner-main .grid-hm .head {
  font-family: "IBM Plex Mono";
  font-weight: 700;
  color: var(--ink-soft);
  font-size: 9px;
  padding: 5px;
  text-align: center;
}

.solution-inner-main .grid-hm .lbl {
  font-weight: 600;
  padding: 6px 4px;
  display: flex;
  align-items: center;
}

.solution-inner-main .cell {
  height: 30px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #fff;
  font-size: 10px;
}

.solution-inner-main .cell.ok {
  background: var(--green);
}

.solution-inner-main .cell.lo {
  background: var(--amber);
}

.solution-inner-main .cell.oo {
  background: var(--red);
}

.solution-inner-main .cell.na {
  background: #cbd5e1;
}

.solution-inner-main .lgd {
  display: flex;
  gap: 11px;
  margin-top: 11px;
  font-size: 10.5px;
  color: var(--ink-soft);
  flex-wrap: wrap;
}

.solution-inner-main .lgd span {
  display: flex;
  align-items: center;
  gap: 5px;
}

.solution-inner-main .lgd i {
  width: 11px;
  height: 11px;
  border-radius: 3px;
  display: inline-block;
}

.solution-inner-main .sec-head.center {
  margin: 0 auto 40px;
  text-align: center;
}

.solution-inner-main .cat-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 13px;
  font-size: 11.5px;
  color: var(--ink-soft);
}

.solution-inner-main .cat-head b {
  color: var(--ink);
}

.solution-inner-main .skubar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 9px;
}

.solution-inner-main .skubar:last-child {
  margin-bottom: 0;
}

.solution-inner-main .skubar .cn3 {
  width: 90px;
  font-size: 11px;
  font-weight: 600;
  flex-shrink: 0;
}

.solution-inner-main .skubar .track2 {
  flex: 1;
  height: 24px;
  background: var(--paper-2);
  border-radius: 6px;
  overflow: hidden;
  position: relative;
}

.solution-inner-main .skubar .fill2 {
  height: 100%;
  display: flex;
  align-items: center;
  padding-left: 8px;
  color: #fff;
  font-size: 10.5px;
  font-weight: 700;
  border-radius: 6px;
}

.solution-inner-main .fill2.hi {
  background: var(--si);
}

.solution-inner-main .fill2.md {
  background: #3b82f6;
}

.solution-inner-main .fill2.lo {
  background: #94a3b8;
}

.solution-inner-main .skubar .vol {
  width: 50px;
  font-size: 11px;
  text-align: right;
  font-weight: 700;
  color: var(--ink-soft);
  flex-shrink: 0;
}

.solution-inner-main .sec-head.center {
  margin: 0 auto 40px;
  text-align: center;
}

.solution-inner-main .ct4 {
  font-size: 11.5px;
  color: var(--ink-soft);
  margin-bottom: 6px;
}

.solution-inner-main .ct4 b {
  color: var(--ink);
}

.solution-inner-main .chart-x {
  display: flex;
  justify-content: space-between;
  font-size: 9.5px;
  color: var(--ink-soft);
  font-family: "IBM Plex Mono";
  margin-top: 6px;
}

.solution-inner-main .pchg {
  margin-top: 12px;
  border-top: 1px solid var(--line);
  padding-top: 11px;
}

.solution-inner-main .ch {
  display: flex;
  justify-content: space-between;
  font-size: 11.5px;
  padding: 5px 0;
  color: var(--ink-soft);
}

.solution-inner-main .ch b {
  color: var(--ink);
}

.solution-inner-main .ch .up {
  color: var(--red);
  font-weight: 700;
}

.solution-inner-main .ch .dn {
  color: var(--green);
  font-weight: 700;
}

.solution-inner-main .sec-head.center {
  margin: 0 auto 40px;
  text-align: center;
}

.solution-inner-main .pincode {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 12px;
  background: #fff8dc;
  border: 1px solid var(--bk);
  border-radius: 9px;
  margin-bottom: 14px;
  font-size: 12px;
}

.solution-inner-main .pincode .lab2 {
  font-family: "IBM Plex Mono";
  font-size: 10px;
  color: #7a5a00;
  text-transform: uppercase;
}

.solution-inner-main .pincode .pn {
  font-weight: 700;
  color: #5c4400;
}

.solution-inner-main .pinrow {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  margin-bottom: 7px;
  font-size: 12px;
}

.solution-inner-main .pinrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .pinrow .pp2 {
  font-weight: 600;
  flex: 1;
}

.solution-inner-main .pinrow .pr {
  font-weight: 700;
  font-family: "IBM Plex Mono";
}

.solution-inner-main .pinrow .stk {
  font-size: 9.5px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 5px;
  text-transform: uppercase;
}

.solution-inner-main .stk.ok {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .stk.lo {
  background: #fdf2e0;
  color: var(--amber);
}

.solution-inner-main .stk.oo {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .sec-head.center {
  margin: 0 auto 40px;
  text-align: center;
}

.solution-inner-main .bbx {
  display: flex;
  gap: 10px;
  margin-bottom: 13px;
}

.solution-inner-main .bbx .bb {
  flex: 1;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px;
  text-align: center;
}

.solution-inner-main .bbx .bb b {
  display: block;
  font-family: "Bricolage Grotesque";
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
}

.solution-inner-main .bbx .bb span {
  font-size: 10px;
  color: var(--ink-soft);
  text-transform: uppercase;
}

.solution-inner-main .bb.win b {
  color: var(--green);
}

.solution-inner-main .bb.lose b {
  color: var(--red);
}

.solution-inner-main .bb.sell b {
  color: var(--accent);
}

.solution-inner-main .lrow {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 9px 12px;
  margin-bottom: 7px;
  font-size: 12px;
}

.solution-inner-main .lrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .lrow .ln {
  flex: 1;
  font-weight: 600;
}

.solution-inner-main .lrow .lp {
  font-weight: 700;
}

.solution-inner-main .lrow .tg {
  font-size: 9px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 5px;
  text-transform: uppercase;
}

.solution-inner-main .tg.win {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .tg.lose {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .srow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .srow .av {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 13px;
  flex-shrink: 0;
  color: #fff;
}

.solution-inner-main .av.ok {
  background: var(--green);
}

.solution-inner-main .av.no {
  background: var(--red);
}

.solution-inner-main .srow .inf {
  flex: 1;
}

.solution-inner-main .srow .sn {
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .srow .mp {
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .srow .bd {
  font-size: 9.5px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  text-transform: uppercase;
}

.solution-inner-main .bd.ok {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .bd.no {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .card-body .ct3 {
  font-size: 11.5px;
  color: var(--ink-soft);
  margin-bottom: 6px;
}

.solution-inner-main .card-body .ct3 b {
  color: var(--ink);
}

.solution-inner-main .chart-x {
  display: flex;
  justify-content: space-between;
  font-size: 9.5px;
  color: var(--ink-soft);
  font-family: "IBM Plex Mono";
  margin-top: 6px;
}

.solution-inner-main .legend {
  display: flex;
  gap: 14px;
  margin-top: 12px;
  font-size: 10.5px;
}

.solution-inner-main .legend span {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--ink-soft);
}

.solution-inner-main .legend i {
  width: 14px;
  height: 3px;
  border-radius: 2px;
  display: inline-block;
}

.solution-inner-main .ela {
  margin-top: 13px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 11px 13px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.solution-inner-main .ela .el {
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .ela .ev {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 17px;
}

.solution-inner-main .ela .tag3 {
  font-size: 9.5px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  background: #fdeef0;
  color: var(--red);
  text-transform: uppercase;
}

.solution-inner-main .card-body .pt2 {
  font-size: 11.5px;
  color: var(--ink-soft);
  margin-bottom: 13px;
}

.solution-inner-main .card-body .pt2 b {
  color: var(--ink);
}

.solution-inner-main .posbar {
  position: relative;
  height: 46px;
  margin: 18px 4px 8px;
}

.solution-inner-main .posbar .track1 {
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  height: 6px;
  border-radius: 4px;
  background: linear-gradient(90deg, #1f9d57, #d98a13, #e23b52);
}

.solution-inner-main .posbar .mk2 {
  position: absolute;
  top: 8px;
  width: 2px;
  height: 30px;
  background: var(--ink-soft);
}

.solution-inner-main .posbar .lab {
  position: absolute;
  top: -4px;
  font-size: 9px;
  color: var(--ink-soft);
  transform: translateX(-50%);
}

.solution-inner-main .posbar .you {
  position: absolute;
  top: 2px;
  transform: translateX(-50%);
  text-align: center;
}

.solution-inner-main .posbar .you .dot2 {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--accent);
  border: 3px solid #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
  margin: 14px auto 0;
}

.solution-inner-main .posbar .you .yl {
  font-size: 9px;
  font-weight: 700;
  color: var(--accent);
}

.solution-inner-main .crow {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  padding: 7px 4px;
  border-bottom: 1px solid var(--line);
}

.solution-inner-main .crow:last-child {
  border-bottom: none;
}

.solution-inner-main .crow .cn2 {
  color: var(--ink-soft);
}

.solution-inner-main .crow .cn2.me {
  color: var(--accent);
  font-weight: 700;
}

.solution-inner-main .crow .cp {
  font-weight: 700;
}

.solution-inner-main .match-grp {
  border: 1.5px solid var(--accent);
  border-radius: 11px;
  padding: 12px;
  background: #f0f5ff;
}

.solution-inner-main .match-grp .gh {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 9px;
}

.solution-inner-main .match-grp .gt {
  font-weight: 700;
  font-size: 12px;
  color: var(--accent);
}

.solution-inner-main .conf {
  font-size: 10px;
  font-weight: 700;
  background: var(--green);
  color: #fff;
  padding: 3px 8px;
  border-radius: 6px;
}

.solution-inner-main .mli {
  display: flex;
  justify-content: space-between;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 11px;
  margin-bottom: 6px;
  font-size: 11.5px;
}

.solution-inner-main .mli:last-child {
  margin-bottom: 0;
}

.solution-inner-main .mli .src {
  color: var(--ink-soft);
}

.solution-inner-main .mli .nm2 {
  font-weight: 600;
}

.solution-inner-main .mli .pp {
  font-weight: 700;
}

.solution-inner-main .sub {
  font-size: 17.5px;
  color: var(--ink-soft);
  margin: 20px 0 26px;
  max-width: 520px;
}

.solution-inner-main .scan {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: 0 24px 50px rgba(21, 24, 31, 0.13);
  overflow: hidden;
}

.solution-inner-main .scan-bar {
  background: var(--ink);
  padding: 13px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.solution-inner-main .scan-bar .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #3a3f4d;
}

.solution-inner-main .scan-bar .ttl {
  margin-left: 8px;
  color: #cfd3db;
  font-family: "IBM Plex Mono";
  font-size: 11px;
  letter-spacing: 0.04em;
}

.solution-inner-main .scan-body {
  padding: 18px;
}

.solution-inner-main .srow1 {
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 13px 14px;
  margin-bottom: 10px;
}

.solution-inner-main .srow1:last-child {
  margin-bottom: 0;
}

.solution-inner-main .srow1 .top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 7px;
}

.solution-inner-main .srow1 .lst {
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.solution-inner-main .badge.hi {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .badge.md {
  background: #fdf2e0;
  color: var(--amber);
}

.solution-inner-main .badge.ok {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .srow1 .sig {
  font-size: 11.5px;
  color: var(--ink-soft);
  line-height: 1.6;
}

.solution-inner-main .srow1 .sig b {
  color: var(--ink);
  font-weight: 600;
}

.solution-inner-main .mrow {
  display: flex;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 12px 13px;
  margin-bottom: 9px;
}

.solution-inner-main .mrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .mrow .inf {
  flex: 1;
}

.solution-inner-main .mrow .sl {
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .mrow .vs {
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .mrow .count {
  text-align: right;
}

.solution-inner-main .mrow .count b {
  font-family: "Bricolage Grotesque";
  font-size: 17px;
  font-weight: 800;
  color: var(--red);
  line-height: 1;
}

.solution-inner-main .mrow .count span {
  font-size: 10px;
  color: var(--ink-soft);
  text-transform: uppercase;
}

.solution-inner-main .sev {
  font-size: 9.5px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 5px;
  text-transform: uppercase;
}

.solution-inner-main .sev.hi {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .sev.md {
  background: #fdf2e0;
  color: var(--amber);
}

.solution-inner-main .crh {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 6px;
  font-family: "IBM Plex Mono";
  font-size: 9px;
  text-transform: uppercase;
  color: var(--ink-soft);
  padding: 6px;
  border-bottom: 1.5px solid var(--ink);
}

.solution-inner-main .cr {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 6px;
  align-items: center;
  padding: 11px 6px;
  border-bottom: 1px solid var(--line);
  font-size: 12px;
}

.solution-inner-main .cr:last-child {
  border-bottom: none;
}

.solution-inner-main .cr .nm {
  font-weight: 600;
}

.solution-inner-main .cr .v {
  text-align: right;
  font-weight: 600;
}

.solution-inner-main .st {
  font-size: 9px;
  font-weight: 700;
  padding: 3px 6px;
  border-radius: 5px;
  text-transform: uppercase;
  text-align: center;
}

.solution-inner-main .st.ok.ok1 {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .st.lo {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .st.dr {
  background: #fdf2e0;
  color: var(--amber);
}

.solution-inner-main .sub {
  font-size: 17.5px;
  color: var(--ink-soft);
  margin: 20px 0 26px;
  max-width: 520px;
}

.solution-inner-main .viol {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: 0 24px 50px rgba(21, 24, 31, 0.13);
  overflow: hidden;
}

.solution-inner-main .viol-bar {
  background: var(--ink);
  padding: 13px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.solution-inner-main .viol-bar .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #3a3f4d;
}

.solution-inner-main .viol-bar .ttl {
  margin-left: 8px;
  color: #cfd3db;
  font-family: "IBM Plex Mono";
  font-size: 11px;
  letter-spacing: 0.04em;
}

.solution-inner-main .viol-body {
  padding: 18px;
}

.solution-inner-main .vrow {
  display: flex;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 12px 13px;
  margin-bottom: 10px;
}

.solution-inner-main .vrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .vrow .st {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.solution-inner-main .st.bad {
  background: var(--red);
}

.solution-inner-main .st.ok {
  background: var(--green);
}

.solution-inner-main .vrow .info {
  flex: 1;
}

.solution-inner-main .vrow .sel {
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .vrow .sub2 {
  font-size: 11.5px;
  color: var(--ink-soft);
}

.solution-inner-main .vrow .gap {
  text-align: right;
}

.solution-inner-main .vrow .gap .pr {
  font-weight: 700;
  font-size: 13px;
}

.solution-inner-main .vrow .gap .pr.bad {
  color: var(--red);
}

.solution-inner-main .vrow .gap .pr.ok {
  color: var(--green);
}

.solution-inner-main .vrow .gap .lab {
  font-size: 10.5px;
  color: var(--ink-soft);
}

.solution-inner-main .card-body .kw {
  font-size: 11.5px;
  color: var(--ink-soft);
  margin-bottom: 12px;
}

.solution-inner-main .slot {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 9px 12px;
  margin-bottom: 7px;
}

.solution-inner-main .slot:last-child {
  margin-bottom: 0;
}

.solution-inner-main .slot .pos {
  font-family: "IBM Plex Mono";
  font-size: 10px;
  color: var(--ink-soft);
  width: 24px;
  flex-shrink: 0;
}

.solution-inner-main .slot .bn {
  flex: 1;
  font-weight: 600;
  font-size: 12.5px;
}

.solution-inner-main .spon {
  font-size: 9px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 5px;
  background: #fdf2e0;
  color: var(--amber);
  text-transform: uppercase;
}

.solution-inner-main .org {
  font-size: 9px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 5px;
  background: var(--paper-2);
  color: var(--ink-soft);
  text-transform: uppercase;
}

.solution-inner-main .slot.you {
  border-color: var(--accent);
  background: #f0f5ff;
}

.solution-inner-main .slot.you .bn {
  color: var(--accent);
}

.solution-inner-main .osrow {
  display: flex;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 11px 13px;
  margin-bottom: 8px;
}

.solution-inner-main .osrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .osrow .dt {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}

.solution-inner-main .dt.r {
  background: var(--red);
}

.solution-inner-main .dt.g {
  background: var(--green);
}

.solution-inner-main .dt.a {
  background: var(--amber);
}

.solution-inner-main .osrow .inf {
  flex: 1;
}

.solution-inner-main .osrow .pn {
  font-weight: 600;
  font-size: 12.5px;
}

.solution-inner-main .osrow .rl {
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .osrow .stt {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  text-transform: uppercase;
}

.solution-inner-main .stt.r {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .stt.g {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .stt.a {
  background: #fdf2e0;
  color: var(--amber);
}

.solution-inner-main .chart-x {
  display: flex;
  justify-content: space-between;
  font-size: 9.5px;
  color: var(--ink-soft);
  font-family: "IBM Plex Mono";
  margin-top: 6px;
}

.solution-inner-main .pts {
  display: flex;
  gap: 14px;
  margin-top: 14px;
  flex-wrap: wrap;
}

.solution-inner-main .pt {
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .pt b {
  display: block;
  font-family: "Bricolage Grotesque";
  font-size: 15px;
  color: var(--ink);
  font-weight: 800;
}

.solution-inner-main .rtop {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.solution-inner-main .rtop .big {
  font-family: "Bricolage Grotesque";
  font-size: 30px;
  font-weight: 800;
  line-height: 1;
}

.solution-inner-main .rtop .stars {
  color: var(--amber);
  font-size: 14px;
  letter-spacing: 1px;
}

.solution-inner-main .rtop .sub2 {
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .theme {
  margin-bottom: 9px;
}

.solution-inner-main .theme:last-child {
  margin-bottom: 0;
}

.solution-inner-main .theme .th {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  margin-bottom: 4px;
}

.solution-inner-main .theme .th .nm {
  font-weight: 600;
}

.solution-inner-main .theme .th .sn {
  font-weight: 700;
}

.solution-inner-main .sn.pos {
  color: var(--green);
}

.solution-inner-main .sn.neg {
  color: var(--red);
}

.solution-inner-main .theme .bar {
  height: 8px;
  border-radius: 5px;
  background: var(--paper-2);
  overflow: hidden;
}

.solution-inner-main .theme .bar i {
  display: block;
  height: 100%;
  border-radius: 5px;
}

.solution-inner-main .bar i.pos {
  background: var(--green);
}

.solution-inner-main .bar i.neg {
  background: var(--red);
}

.solution-inner-main .donut-wrap {
  display: flex;
  align-items: center;
  gap: 18px;
}

.solution-inner-main .donut {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  flex-shrink: 0;
  background: conic-gradient(
    var(--accent) 0 31%,
    #7da6f5 31% 53%,
    #c2cad8 53% 74%,
    #e1e6ef 74% 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
}

.solution-inner-main .donut i {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-style: normal;
}

.solution-inner-main .donut i b {
  font-family: "Bricolage Grotesque";
  font-size: 22px;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}

.solution-inner-main .donut i span {
  font-size: 9px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.solution-inner-main .leg {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 12px;
}

.solution-inner-main .leg div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.solution-inner-main .leg .sw {
  width: 11px;
  height: 11px;
  border-radius: 3px;
  flex-shrink: 0;
}

.solution-inner-main .sw.a {
  background: var(--accent);
}

.solution-inner-main .sw.b {
  background: #7da6f5;
}

.solution-inner-main .sw.c {
  background: #c2cad8;
}

.solution-inner-main .sw.d {
  background: #e1e6ef;
}

.solution-inner-main .prow {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 11px 13px;
  margin-bottom: 8px;
}

.solution-inner-main .prow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .prow .rt {
  flex: 1;
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .prow .pp {
  font-weight: 700;
  font-size: 13px;
}

.solution-inner-main .prow .tag {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  text-transform: uppercase;
}

.solution-inner-main .tag.ok {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .tag.lo {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .tag.pr {
  background: #e5edfd;
  color: var(--accent);
}

.solution-inner-main .card-body .pname {
  font-weight: 600;
  font-size: 12.5px;
  color: var(--ink-soft);
  margin-bottom: 11px;
}

.solution-inner-main .arow {
  display: flex;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 11px 13px;
  margin-bottom: 8px;
}

.solution-inner-main .arow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .arow .rt {
  flex: 1;
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .arow .badge {
  font-size: 10px;
  font-weight: 700;
  padding: 4px 9px;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.solution-inner-main .badge.ls {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .badge.oos {
  background: #fdf2e0;
  color: var(--amber);
}

.solution-inner-main .badge.del {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .score {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 11px;
  margin-bottom: 13px;
}

.solution-inner-main .score .ring {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: conic-gradient(var(--amber) 0 62%, var(--paper-2) 62% 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.solution-inner-main .score .ring i {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-style: normal;
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 14px;
}

.solution-inner-main .score .st {
  font-size: 12.5px;
}

.solution-inner-main .score .st b {
  display: block;
  font-family: "Bricolage Grotesque";
  font-size: 14px;
}

.solution-inner-main .chk {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  padding: 8px 4px;
  border-bottom: 1px solid var(--line);
}

.solution-inner-main .chk:last-child {
  border-bottom: none;
}

.solution-inner-main .chk .ic {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
}

.solution-inner-main .ic.ok {
  background: var(--green);
}

.solution-inner-main .ic.no {
  background: var(--red);
}

.solution-inner-main .ic.wn {
  background: var(--amber);
}

.solution-inner-main .sos {
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.solution-inner-main .sbar .sh {
  display: flex;
  justify-content: space-between;
  font-size: 12.5px;
  margin-bottom: 5px;
}

.solution-inner-main .sbar .sh .bn {
  font-weight: 600;
}

.solution-inner-main .sbar .sh .pc {
  font-weight: 700;
}

.solution-inner-main .sbar .track {
  height: 11px;
  border-radius: 6px;
  background: var(--paper-2);
  overflow: hidden;
  padding: 0;
}

.solution-inner-main .sbar .fill {
  height: 100%;
  border-radius: 6px;
}

.solution-inner-main .fill.you {
  background: var(--accent);
}

.solution-inner-main .fill.c {
  background: #c2cad8;
}

.solution-inner-main .subgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.solution-inner-main .subc {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 9px;
  transition:
    transform 0.15s,
    box-shadow 0.15s,
    border-color 0.15s;
}

.solution-inner-main .subc:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(21, 24, 31, 0.08);
  border-color: var(--accent);
}

.solution-inner-main .subc .tg {
  font-family: "IBM Plex Mono";
  font-size: 10px;
  color: var(--orange);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.solution-inner-main .subc h4 {
  font-size: 17px;
  line-height: 1.25;
}

.solution-inner-main .subc p {
  font-size: 13.5px;
  color: var(--ink-soft);
  flex: 1;
}

.solution-inner-main .subc .arr2 {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  color: var(--accent);
  font-size: 14px;
  align-self: flex-start;
  transition: transform 0.15s;
}

.solution-inner-main .subc:hover .arr2 {
  transform: translateX(4px);
}

.solution-inner-main .qrow {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 11px 13px;
  border: 1px solid var(--line);
  border-radius: 11px;
  margin-bottom: 7px;
}

.solution-inner-main .qrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .qrow .lg {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  color: #fff;
  font-size: 13px;
  flex-shrink: 0;
}

.solution-inner-main .lg.bk {
  background: #f8cb46;
  color: #000;
}

.solution-inner-main .lg.zp {
  background: #7c3aed;
}

.solution-inner-main .lg.si {
  background: #fc8019;
}

.solution-inner-main .lg.gp {
  background: #3b82f6;
}

.solution-inner-main .qrow .nm {
  flex: 1;
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .qrow .nm small {
  display: block;
  font-weight: 400;
  color: var(--ink-soft);
  font-size: 11px;
}

.solution-inner-main .qrow .tm {
  font-family: "IBM Plex Mono";
  font-size: 11px;
  font-weight: 700;
  color: var(--orange);
}

.solution-inner-main .sec-head.center {
  margin: 0 auto 40px;
  text-align: center;
}

.solution-inner-main .honest {
  background: #fff5ef;
  border: 1px solid #ffd1ba;
  color: #7a3a1a;
  border-radius: 11px;
  padding: 18px 22px;
  margin: 18px 0 0;
  font-size: 14px;
  line-height: 1.7;
}

.solution-inner-main .honest b {
  color: #5c2a13;
}

.solution-inner-main .lrow {
  display: flex;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 11px 13px;
  margin-bottom: 8px;
}

.solution-inner-main .lrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .lrow .pin {
  font-size: 15px;
}

.solution-inner-main .lrow .loc {
  flex: 1;
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .lrow .loc span {
  display: block;
  font-weight: 400;
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .lrow .pr {
  font-weight: 700;
  font-size: 13.5px;
}

.solution-inner-main .lrow .pr.hi {
  color: var(--red);
}

.solution-inner-main .lrow .pr.lo {
  color: var(--green);
}

.solution-inner-main .srow {
  display: flex;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 13px;
  margin-bottom: 9px;
}

.solution-inner-main .srow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .srow .num {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 13px;
  color: #fff;
  background: var(--accent);
  width: 30px;
  height: 30px;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.solution-inner-main .srow .info {
  flex: 1;
}

.solution-inner-main .srow .nm {
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .srow .ds {
  font-size: 11.5px;
  color: var(--ink-soft);
}

.solution-inner-main .crow {
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 12px 13px;
  margin-bottom: 9px;
}

.solution-inner-main .crow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .crow .top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 5px;
}

.solution-inner-main .crow .nm {
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .pill {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.solution-inner-main .pill.r {
  background: #fdeef0;
  color: var(--red);
}

.solution-inner-main .pill.a {
  background: #fdf2e0;
  color: var(--amber);
}

.solution-inner-main .pill.g {
  background: #e4f6ec;
  color: var(--green);
}

.solution-inner-main .crow .det {
  font-size: 11.5px;
  color: var(--ink-soft);
}

.solution-inner-main .crow .det b {
  color: var(--ink);
  font-weight: 600;
}

.solution-inner-main .grow {
  margin-bottom: 14px;
}

.solution-inner-main .grow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .grow .gh {
  display: flex;
  justify-content: space-between;
  font-size: 12.5px;
  margin-bottom: 6px;
}

.solution-inner-main .grow .gh .cat {
  font-weight: 600;
}

.solution-inner-main .grow .gh .gp {
  font-weight: 700;
  color: var(--red);
}

.solution-inner-main .bar {
  height: 9px;
  border-radius: 6px;
  background: var(--paper-2);
  position: relative;
  overflow: hidden;
}

.solution-inner-main .bar .you {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: var(--accent);
  border-radius: 6px;
}

.solution-inner-main .bar .mkt {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: repeating-linear-gradient(
    45deg,
    #cdd4e0,
    #cdd4e0 5px,
    #dbe1ea 5px,
    #dbe1ea 10px
  );
  border-radius: 6px;
  z-index: -0;
}

.solution-inner-main .glegend {
  display: flex;
  gap: 14px;
  font-size: 11px;
  color: var(--ink-soft);
  margin-top: 12px;
}

.solution-inner-main .glegend span {
  display: flex;
  align-items: center;
  gap: 6px;
}

.solution-inner-main .glegend .sw {
  width: 11px;
  height: 11px;
  border-radius: 3px;
}

.solution-inner-main .sw.s1 {
  background: var(--accent);
}

.solution-inner-main .sw.s2 {
  background: #cdd4e0;
}

.solution-inner-main .feed {
  background: #0f1320;
  padding: 18px;
  font-family: "IBM Plex Mono";
  font-size: 12px;
  line-height: 1.85;
  color: #cdd3e0;
}

.solution-inner-main .feed .k {
  color: #8fb4ff;
}

.solution-inner-main .feed .s {
  color: #7fd1a6;
}

.solution-inner-main .feed .n {
  color: #e6b873;
}

.solution-inner-main .feed .br {
  color: #5a6582;
}

.solution-inner-main .feed-foot {
  background: var(--cream);
  padding: 13px 16px;
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
}

.solution-inner-main .fchip {
  font-size: 11px;
  font-weight: 600;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 11px;
  color: var(--ink-soft);
}

.solution-inner-main .fchip.on {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.solution-inner-main .pain {
  background: var(--paper-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.solution-inner-main .crow {
  display: flex;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 12px 13px;
  margin-bottom: 9px;
}

.solution-inner-main .crow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .crow .ch {
  flex: 1;
  font-weight: 600;
  font-size: 13px;
}

.solution-inner-main .crow .ch span {
  display: block;
  font-weight: 400;
  font-size: 11px;
  color: var(--ink-soft);
}

.solution-inner-main .crow .pr {
  font-weight: 700;
  font-size: 13.5px;
}

.solution-inner-main .crow .pr.bad {
  color: var(--red);
}

.solution-inner-main .crow .pr.ok {
  color: var(--ink);
}

.solution-inner-main .sub {
  font-size: 17.5px;
  color: var(--ink-soft);
  margin: 20px 0 26px;
  max-width: 520px;
}

.solution-inner-main .reco {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: 0 24px 50px rgba(21, 24, 31, 0.13);
  overflow: hidden;
}

.solution-inner-main .reco-bar {
  background: var(--ink);
  padding: 13px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.solution-inner-main .reco-bar .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #3a3f4d;
}

.solution-inner-main .reco-bar .ttl {
  margin-left: 8px;
  color: #cfd3db;
  font-family: "IBM Plex Mono";
  font-size: 11px;
  letter-spacing: 0.04em;
}

.solution-inner-main .reco-body {
  padding: 18px;
}

.solution-inner-main .reco-item {
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 14px 15px;
  margin-bottom: 11px;
}

.solution-inner-main .reco-item:last-child {
  margin-bottom: 0;
}

.solution-inner-main .reco-item .nm {
  font-weight: 600;
  font-size: 13.5px;
  margin-bottom: 9px;
}

.solution-inner-main .reco-row {
  display: flex;
  justify-content: space-between;
  font-size: 12.5px;
  margin-bottom: 5px;
}

.solution-inner-main .reco-row .lab {
  color: var(--ink-soft);
}

.solution-inner-main .reco-row .val {
  font-weight: 600;
}

.solution-inner-main .reco-reco {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 9px;
  padding-top: 9px;
  border-top: 1px dashed var(--line);
  font-size: 13px;
}

.solution-inner-main .reco-reco .new {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  color: var(--accent);
  font-size: 16px;
}

.solution-inner-main .tag-up {
  font-size: 11px;
  font-weight: 700;
  color: var(--green);
  background: #e4f6ec;
  padding: 3px 8px;
  border-radius: 6px;
}

.solution-inner-main .tag-dn {
  font-size: 11px;
  font-weight: 700;
  color: var(--red);
  background: #fdeef0;
  padding: 3px 8px;
  border-radius: 6px;
}

.solution-inner-main .sub {
  font-size: 17.5px;
  color: var(--ink-soft);
  margin: 20px 0 26px;
  max-width: 520px;
}

.solution-inner-main .card {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: 0 24px 50px rgba(21, 24, 31, 0.13);
  overflow: hidden;
}

.solution-inner-main .card-bar {
  background: var(--ink);
  padding: 13px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.solution-inner-main .card-bar .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #3a3f4d;
}

.solution-inner-main .card-bar .ttl {
  margin-left: 8px;
  color: #cfd3db;
  font-family: "IBM Plex Mono";
  font-size: 11px;
  letter-spacing: 0.04em;
}

.solution-inner-main .card-body {
  padding: 18px;
}

.solution-inner-main .sku-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: #fff8ef;
  border: 1px solid #ffd1ba;
  border-radius: 9px;
  margin-bottom: 14px;
  font-size: 12px;
}

.solution-inner-main .sku-hdr .sn {
  font-weight: 700;
  color: #7a3a1a;
}

.solution-inner-main .sku-hdr .sgap {
  font-family: "IBM Plex Mono";
  font-weight: 700;
  color: var(--orange);
  font-size: 13px;
}

.solution-inner-main .pinrow {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 13px;
  border: 1px solid var(--line);
  border-radius: 10px;
  margin-bottom: 6px;
  font-size: 12.5px;
}

.solution-inner-main .pinrow:last-child {
  margin-bottom: 0;
}

.solution-inner-main .pinrow .city {
  flex: 1;
  font-weight: 600;
}

.solution-inner-main .pinrow .pin {
  font-family: "IBM Plex Mono";
  color: var(--ink-soft);
  font-size: 11px;
}

.solution-inner-main .pinrow .pr {
  font-weight: 800;
  font-family: "IBM Plex Mono";
  font-size: 14px;
}

.solution-inner-main .pinrow.lowest .pr {
  color: var(--green);
}

.solution-inner-main .pinrow.highest .pr {
  color: var(--red);
}

.solution-inner-main .pinrow.lowest {
  background: #f0faf4;
  border-color: #bce5cb;
}

.solution-inner-main .pinrow.highest {
  background: #fdeef0;
  border-color: #f7c1c1;
}

.solution-inner-main .sec-head.center {
  margin: 0 auto 40px;
  text-align: center;
}

.solution-inner-main .pain {
  background: var(--paper-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.solution-inner-main .pain-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
}

.solution-inner-main .pain-cell {
  background: var(--cream);
  padding: 30px 26px;
}

.solution-inner-main .pain-cell .x {
  font-family: "Bricolage Grotesque";
  font-size: 20px;
  color: var(--accent);
  font-weight: 800;
  margin-bottom: 11px;
}

.solution-inner-main .pain-cell h4 {
  font-size: 17px;
  margin-bottom: 7px;
}

.solution-inner-main .pain-cell p {
  font-size: 14px;
  color: var(--ink-soft);
}

.solution-inner-main .feat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
}

.solution-inner-main .feat {
  background: var(--cream);
  padding: 26px 28px;
  display: flex;
  gap: 16px;
}

.solution-inner-main .feat .mk {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 14px;
  color: #fff;
  background: var(--accent);
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.solution-inner-main .feat h4 {
  font-size: 16.5px;
  margin-bottom: 5px;
}

.solution-inner-main .feat p {
  font-size: 14px;
  color: var(--ink-soft);
}

.solution-inner-main .why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.solution-inner-main .why {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 26px 24px;
}

.solution-inner-main .why .ic {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  margin-bottom: 14px;
}

.solution-inner-main .why h4 {
  font-size: 16.5px;
  margin-bottom: 7px;
}

.solution-inner-main .why p {
  font-size: 14px;
  color: var(--ink-soft);
}

.solution-inner-main .qa.open .pm {
  transform: rotate(45deg);
}

.solution-inner-main .reveal.in {
  opacity: 1;
  transform: none;
}

@media (max-width: 960px) {
  .solution-inner-main .pain-grid,
  .solution-inner-main .why-grid {
    grid-template-columns: 1fr 1fr;
  }

  .solution-inner-main .feat-grid {
    grid-template-columns: 1fr;
  }

  .solution-inner-main .nav-links,
  .solution-inner-main .nav-cta .btn-ghost {
    display: none;
  }

  .solution-inner-main .subgrid {
    grid-template-columns: 1fr 1fr;
  }
  .solution-inner-main .card-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .solution-inner-main .pain-grid,
  .solution-inner-main .why-grid {
    grid-template-columns: 1fr;
  }

  .solution-inner-main .subgrid {
    grid-template-columns: 1fr;
  }
}

.solution-inner-main .geo {
  background: var(--teal);
  color: var(--cream);
  padding: 64px 0;
  border-top: 1px solid var(--ink);
}
.solution-inner-main .geo .sec-head h2 {
  color: var(--cream);
}
.solution-inner-main .geo .sec-head p {
  color: #aab3c9;
}
.solution-inner-main .geo .sec-head .eyebrow {
  color: #8fb4ff;
}
.solution-inner-main .geo .sec-head .eyebrow::before {
  background: #8fb4ff;
}
.solution-inner-main .geo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.solution-inner-main .geo-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: var(--r);
  padding: 22px 22px;
}
.solution-inner-main .geo-card .gf {
  font-size: 22px;
}
.solution-inner-main .geo-card h4 {
  font-size: 16px;
  margin: 8px 0 6px;
  color: var(--cream);
}
.solution-inner-main .geo-card p {
  font-size: 13px;
  color: #aab3c9;
  line-height: 1.55;
}
.solution-inner-main .geo-card .plat {
  margin-top: 9px;
  font-family: "IBM Plex Mono";
  font-size: 11px;
  color: #8fb4ff;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.solution-inner-main .qa.open .pm {
  transform: rotate(45deg);
}
@media (max-width: 960px) {
  .solution-inner-main .card-body {
    grid-template-columns: 1fr;
  }
  .solution-inner-main .pain-grid,
  .solution-inner-main .geo-grid {
    grid-template-columns: 1fr 1fr;
  }
  .solution-inner-main .feat-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 600px) {
  .solution-inner-main .pain-grid,
  .solution-inner-main .geo-grid {
    grid-template-columns: 1fr;
  }
}

.solution-inner-main .feat {
  background: var(--cream);
  padding: 26px 28px;
  display: flex;
  gap: 16px;
}
.solution-inner-main .feat .mk {
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  font-size: 14px;
  color: #fff;
  background: var(--accent);
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.solution-inner-main .feat h4 {
  font-size: 16.5px;
  margin-bottom: 5px;
}
.solution-inner-main .feat p {
  font-size: 14px;
  color: var(--ink-soft);
}
.solution-inner-main .geo {
  background: var(--teal);
  color: var(--cream);
  border-top: 1px solid var(--ink);
}
.solution-inner-main .geo .sec-head h2 {
  color: var(--cream);
}
.solution-inner-main .geo .sec-head p {
  color: #aab3c9;
}
.solution-inner-main .geo .eyebrow {
  color: #8fb4ff;
}
.solution-inner-main .geo .eyebrow::before {
  background: #8fb4ff;
}
.solution-inner-main .cty-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.solution-inner-main .cty {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: var(--r);
  padding: 24px 22px;
}
.solution-inner-main .cty .fl {
  font-size: 24px;
}
.solution-inner-main .cty h4 {
  font-size: 16px;
  margin: 9px 0 7px;
}
.solution-inner-main .cty p {
  font-size: 13px;
  color: #aab3c9;
}
.solution-inner-main .why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.solution-inner-main .why {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 26px 24px;
}
.solution-inner-main .why .ic {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  /* background: var(--accent); */
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Bricolage Grotesque";
  font-weight: 800;
  margin-bottom: 14px;
  padding: 5px;
}
.solution-inner-main .why h4 {
  font-size: 16.5px;
  margin-bottom: 7px;
}
.solution-inner-main .why p {
  font-size: 14px;
  color: var(--ink-soft);
}
.solution-inner-main .qa.open .pm {
  transform: rotate(45deg);
}
@media (max-width: 960px) {
  .solution-inner-main .strip-inner,
  .solution-inner-main .cty-grid,
  .solution-inner-main .pain-grid,
  .solution-inner-main .uc-grid,
  .solution-inner-main .why-grid {
    grid-template-columns: 1fr 1fr;
  }
  .solution-inner-main .feat-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 600px) {
  .solution-inner-main .strip-inner,
  .solution-inner-main .cty-grid,
  .solution-inner-main .pain-grid,
  .solution-inner-main .uc-grid,
  .solution-inner-main .why-grid,
  .solution-inner-main .steps {
    grid-template-columns: 1fr;
  }
}

.solution-inner-main .hero-ctas .btn.btn-primary {
  display: none;
}
