.elementor-2884 .elementor-element.elementor-element-4aa96066{--display:flex;}/* Start custom CSS */*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    body {

      font-family: 'Inter', sans-serif;

      background: #f5f5f0;

      color: #1a1a1a;

      line-height: 1.7;

    }
    /* ── Top Bar ── */

    .site-bar {

      background: #0a0a0a;

      padding: 0 24px;

      display: flex;

      align-items: center;

      justify-content: space-between;

      height: 56px;

    }

    .site-bar .logo {

      font-size: 18px;

      font-weight: 800;

      color: #fff;

      letter-spacing: 1px;

      text-decoration: none;

    }

    .site-bar .logo span { color: #6c63ff; }

    .site-bar nav a {

      color: #aaa;

      text-decoration: none;

      font-size: 13px;

      margin-left: 24px;

      transition: color .2s;

    }

    .site-bar nav a:hover { color: #fff; }
    /* ── Hero ── */

    .hero {

      background: linear-gradient(135deg, #0f0c29 0%, #1a1040 50%, #24243e 100%);

      padding: 72px 24px 64px;

      text-align: center;

      position: relative;

      overflow: hidden;

    }

    .hero::before {

      content: '';

      position: absolute; inset: 0;

      background: radial-gradient(ellipse 70% 60% at 50% 0%, rgba(108,99,255,.25) 0%, transparent 70%);

    }

    .hero .category-pill {

      display: inline-flex;

      align-items: center;

      gap: 6px;

      background: rgba(108,99,255,.18);

      border: 1px solid rgba(108,99,255,.4);

      color: #a89eff;

      font-size: 12px;

      font-weight: 600;

      letter-spacing: .8px;

      text-transform: uppercase;

      padding: 5px 14px;

      border-radius: 100px;

      margin-bottom: 24px;

      position: relative;

    }

    .hero .category-pill::before {

      content: '';

      width: 6px; height: 6px;

      background: #6c63ff;

      border-radius: 50%;

      display: inline-block;

      box-shadow: 0 0 8px #6c63ff;

    }

    .hero h1 {

      font-family: 'Merriweather', Georgia, serif;

      font-size: clamp(28px, 5vw, 52px);

      font-weight: 700;

      color: #fff;

      line-height: 1.2;

      max-width: 820px;

      margin: 0 auto 20px;

      position: relative;

    }

    .hero h1 em {

      font-style: italic;

      background: linear-gradient(90deg, #a89eff, #f49cbb);

      -webkit-background-clip: text;

      -webkit-text-fill-color: transparent;

      background-clip: text;

    }

    .hero .subtitle {

      font-size: 17px;

      color: #b0aac8;

      max-width: 600px;

      margin: 0 auto 36px;

      position: relative;

    }

    .hero .meta {

      display: flex;

      align-items: center;

      justify-content: center;

      gap: 20px;

      font-size: 13px;

      color: #7a7390;

      position: relative;

      flex-wrap: wrap;

    }

    .hero .meta .author {

      display: flex;

      align-items: center;

      gap: 8px;

      color: #c8c0e0;

    }

    .hero .meta .avatar {

      width: 32px; height: 32px;

      background: linear-gradient(135deg,#6c63ff,#f49cbb);

      border-radius: 50%;

      display: flex; align-items: center; justify-content: center;

      font-size: 13px; font-weight: 700; color: #fff;

    }

    .hero .meta .sep { color: #3a3550; }
    /* ── Layout ── */

    .page-wrap {

      max-width: 1170px;

      margin: 0 auto;

      padding: 0 24px;

    }
    /* ── Reading Progress ── */

    .progress-bar {

      position: fixed;

      top: 0; left: 0;

      height: 3px;

      background: linear-gradient(90deg,#6c63ff,#f49cbb);

      width: 0%;

      z-index: 9999;

      transition: width .1s linear;

      box-shadow: 0 0 8px rgba(108,99,255,.6);

    }
    /* ── Article Layout ── */

    .article-layout {

      display: grid;

      grid-template-columns: 1fr 300px;

      gap: 48px;

      padding: 56px 0 80px;

      align-items: start;

    }

    @media(max-width:900px){

      .article-layout { grid-template-columns: 1fr; }

      .sidebar { display: none; }

    }
    /* ── Article Body ── */

    .article-body {

      background: #fff;

      border-radius: 16px;

      padding: 52px 56px;

      box-shadow: 0 2px 40px rgba(0,0,0,.06);

    }

    @media(max-width:600px){

      .article-body { padding: 32px 24px; }

    }
    .article-body .intro {

      font-family: 'Merriweather', Georgia, serif;

      font-size: 18px;

      line-height: 1.8;

      color: #2d2d2d;

      border-left: 3px solid #6c63ff;

      padding-left: 20px;

      margin-bottom: 40px;

    }
    .article-body h2 {

      font-family: 'Inter', sans-serif;

      font-size: 22px;

      font-weight: 800;

      color: #0f0c29;

      margin: 48px 0 16px;

      padding-bottom: 10px;

      border-bottom: 2px solid #f0eeff;

      display: flex;

      align-items: center;

      gap: 10px;

    }

    .article-body h2 .num {

      background: linear-gradient(135deg,#6c63ff,#9b92ff);

      color: #fff;

      font-size: 12px;

      font-weight: 700;

      padding: 3px 9px;

      border-radius: 6px;

      flex-shrink: 0;

    }
    .article-body h3 {

      font-size: 17px;

      font-weight: 700;

      color: #1a1a2e;

      margin: 32px 0 10px;

    }
    .article-body p {

      font-size: 16px;

      color: #3a3a4a;

      margin-bottom: 18px;

      line-height: 1.85;

    }
    /* ── Pillar Cards ── */

    .pillars {

      display: grid;

      grid-template-columns: 1fr 1fr;

      gap: 16px;

      margin: 28px 0 36px;

    }

    @media(max-width:560px){ .pillars { grid-template-columns: 1fr; } }

    .pillar-card {

      background: #f8f7ff;

      border: 1px solid #ebe8ff;

      border-radius: 12px;

      padding: 20px;

    }

    .pillar-card .icon {

      font-size: 24px;

      margin-bottom: 10px;

    }

    .pillar-card h4 {

      font-size: 14px;

      font-weight: 700;

      color: #6c63ff;

      text-transform: uppercase;

      letter-spacing: .6px;

      margin-bottom: 6px;

    }

    .pillar-card p {

      font-size: 14px;

      color: #555;

      margin: 0;

      line-height: 1.6;

    }
    /* ── Pull Quote ── */

    .pull-quote {

      background: linear-gradient(135deg, #0f0c29, #1e1b4b);

      border-radius: 14px;

      padding: 32px 36px;

      margin: 36px 0;

      position: relative;

      overflow: hidden;
      
      color: white;

    }

    .pull-quote::before {

      content: '"';

      position: absolute;

      top: -10px; left: 20px;

      font-size: 120px;

      color: rgba(108,99,255,.2);

      font-family: Georgia, serif;

      line-height: 1;

    }

    .pull-quote p {

      font-family: 'Merriweather', Georgia, serif;

      font-size: 19px;

      font-style: italic;

      color: #e8e4ff;

      line-height: 1.7;

      margin: 0;

      position: relative;

    }
    
    pull-quotes { color:white; }
    
    
    /* ── Comparison Table ── */

    .table-wrap {

      overflow-x: auto;

      margin: 28px 0 36px;

      border-radius: 12px;

      box-shadow: 0 2px 20px rgba(0,0,0,.08);

    }

    table {

      width: 100%;

      border-collapse: collapse;

      font-size: 14px;

    }

    table thead tr {

      background: linear-gradient(135deg,#0f0c29,#1e1b4b);

    }

    table thead th {

      color: #fff;

      padding: 14px 18px;

      text-align: left;

      font-weight: 600;

      font-size: 13px;

      letter-spacing: .4px;

    }

    table thead th:first-child { border-radius: 12px 0 0 0; }

    table thead th:last-child  { border-radius: 0 12px 0 0; }

    table tbody tr:nth-child(odd)  { background: #faf9ff; }

    table tbody tr:nth-child(even) { background: #fff; }

    table tbody tr:last-child td:first-child { border-radius: 0 0 0 12px; }

    table tbody tr:last-child td:last-child  { border-radius: 0 0 12px 0; }

    table tbody td {

      padding: 13px 18px;

      color: #3a3a4a;

      border-bottom: 1px solid #f0eeff;

      vertical-align: top;

      line-height: 1.5;

    }

    table tbody td:first-child { font-weight: 600; color: #1a1a2e; }
    /* ── Industry Cards ── */

    .industry-grid {

      display: grid;

      grid-template-columns: repeat(3,1fr);

      gap: 16px;

      margin: 28px 0 36px;

    }

    @media(max-width:640px){ .industry-grid { grid-template-columns: 1fr; } }

    .industry-card {

      border-radius: 12px;

      padding: 24px 20px;

      position: relative;

      overflow: hidden;

    }

    .industry-card.ecom   { background: linear-gradient(135deg,#fef3f0,#fde8e0); border: 1px solid #f9c9b8; }

    .industry-card.dev    { background: linear-gradient(135deg,#f0f4ff,#e0e8ff); border: 1px solid #b8c9f9; }

    .industry-card.legal  { background: linear-gradient(135deg,#f0fff4,#e0ffe8); border: 1px solid #b8f9c9; }

    .industry-card .ic-icon { font-size: 28px; margin-bottom: 10px; }

    .industry-card h4 { font-size: 14px; font-weight: 700; color: #1a1a2e; margin-bottom: 8px; }

    .industry-card p  { font-size: 13px; color: #555; margin: 0; line-height: 1.55; }
    /* ── Threat List ── */

    .threat-list {

      list-style: none;

      margin: 20px 0 30px;

      display: flex;

      flex-direction: column;

      gap: 12px;

    }

    .threat-list li {

      display: flex;

      align-items: flex-start;

      gap: 12px;

      background: #fff5f5;

      border: 1px solid #fdd;

      border-left: 4px solid #e53e3e;

      border-radius: 8px;

      padding: 14px 16px;

      font-size: 15px;

      color: #3a3a4a;

      line-height: 1.6;

    }

    .threat-list li .threat-icon { font-size: 18px; flex-shrink: 0; margin-top: 1px; }

    .threat-list li strong { color: #c53030; }
    /* ── Blueprint Cards ── */

    .blueprint {

      display: grid;

      grid-template-columns: repeat(3,1fr);

      gap: 14px;

      margin: 20px 0 36px;

    }

    @media(max-width:640px){ .blueprint { grid-template-columns: 1fr; } }

    .bp-card {

      background: linear-gradient(135deg,#0f0c29,#1e1b4b);

      border-radius: 12px;

      padding: 20px;

      color: #fff;

      text-align: center;

    }

    .bp-card .bp-icon { font-size: 30px; margin-bottom: 10px; }

    .bp-card h4 { font-size: 14px; font-weight: 700; color: #a89eff; margin-bottom: 6px; }

    .bp-card p  { font-size: 13px; color: #8c84b0; margin: 0; line-height: 1.5; }
    /* ── Optimization Steps ── */

    .steps {

      counter-reset: steps;

      list-style: none;

      margin: 20px 0 36px;

      display: flex;

      flex-direction: column;

      gap: 14px;

    }

    .steps li {

      counter-increment: steps;

      display: flex;

      gap: 16px;

      align-items: flex-start;

      background: #f8f7ff;

      border: 1px solid #ebe8ff;

      border-radius: 10px;

      padding: 16px 18px;

    }

    .steps li::before {

      content: counter(steps);

      background: linear-gradient(135deg,#6c63ff,#9b92ff);

      color: #fff;

      font-size: 13px;

      font-weight: 800;

      min-width: 28px;

      height: 28px;

      border-radius: 50%;

      display: flex;

      align-items: center;

      justify-content: center;

      flex-shrink: 0;

    }

    .steps li .step-body h4 { font-size: 15px; font-weight: 700; color: #1a1a2e; margin-bottom: 4px; }

    .steps li .step-body p  { font-size: 14px; color: #555; margin: 0; line-height: 1.55; }
    /* ── Swarm Banner ── */

    .swarm-banner {

      background: linear-gradient(135deg,#0f0c29 0%,#1e1b4b 100%);

      border-radius: 14px;

      padding: 36px;

      margin: 36px 0;

      display: flex;

      align-items: center;

      gap: 24px;

    }

    @media(max-width:560px){ .swarm-banner { flex-direction: column; text-align: center; } }

    .swarm-banner .sb-icon { font-size: 48px; flex-shrink: 0; }

    .swarm-banner h3 { font-size: 18px; font-weight: 800; color: #fff; margin-bottom: 6px; }

    .swarm-banner p  { font-size: 14px; color: #9890b8; margin: 0; line-height: 1.6; }
    /* ── CTA Box ── */

    .cta-box {

      background: linear-gradient(135deg,#6c63ff 0%,#9b59b6 100%);

      border-radius: 16px;

      padding: 40px 44px;

      text-align: center;

      margin-top: 48px;

    }

    .cta-box h3 { font-size: 22px; font-weight: 800; color: #fff; margin-bottom: 10px; }

    .cta-box p  { font-size: 16px; color: rgba(255,255,255,.8); margin-bottom: 28px; line-height: 1.6; }

    .cta-box .btn-row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

    .cta-box a.btn {

      display: inline-block;

      padding: 12px 28px;

      border-radius: 8px;

      font-size: 14px;

      font-weight: 700;

      text-decoration: none;

      transition: transform .2s, box-shadow .2s;

    }

    .cta-box a.btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.25); }

    .cta-box a.btn-white { background: #fff; color: #6c63ff; }

    .cta-box a.btn-outline { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.5); }
    /* ── Sidebar ── */

    .sidebar { display: flex; flex-direction: column; gap: 24px; position: sticky; top: 24px; }
    .sidebar-card {

      background: #fff;

      border-radius: 14px;

      padding: 24px;

      box-shadow: 0 2px 20px rgba(0,0,0,.06);

    }

    .sidebar-card h4 {

      font-size: 12px;

      font-weight: 700;

      text-transform: uppercase;

      letter-spacing: .8px;

      color: #9890b8;

      margin-bottom: 16px;

    }
    /* TOC */

    .toc-list { list-style: none; display: flex; flex-direction: column; gap: 4px; }

    .toc-list a {

      display: block;

      padding: 7px 10px;

      border-radius: 7px;

      font-size: 13px;

      color: #555;

      text-decoration: none;

      transition: background .15s, color .15s;

    }

    .toc-list a:hover { background: #f0eeff; color: #6c63ff; }
    /* Tags */

    .tag-cloud { display: flex; flex-wrap: wrap; gap: 8px; }

    .tag-cloud a {

      display: inline-block;

      padding: 5px 12px;

      background: #f5f3ff;

      border: 1px solid #ddd8ff;

      color: #6c63ff;

      font-size: 12px;

      font-weight: 600;

      border-radius: 100px;

      text-decoration: none;

      transition: background .15s, border-color .15s;

    }

    .tag-cloud a:hover { background: #6c63ff; color: #fff; border-color: #6c63ff; }
html {
    scroll-behavior: smooth;
}

/* Share Buttons - Matching Template Style */
.share-btns {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 12px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 1px solid transparent;
}

.share-btn.tw {
    background: #000;
    color: #fff;
}

.share-btn.li {
    background: #0077b5;
    color: #fff;
}

.share-btn.cp {
    background: #f3f4f6;
    color: #1f2937;
    border: 1px solid #e5e7eb;
}

.share-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    opacity: 0.9;
}

/* TOC Active State */
.toc-list a.active {
    color: #6c63ff;
    background: #f0eeff;
    font-weight: 700;
    border-left: 3px solid #6c63ff;
}
    /* ── Footer ── */

    footer {

      background: #0a0a0a;

      color: #666;

      text-align: center;

      padding: 28px 24px;

      font-size: 13px;

    }

    footer span { color: #6c63ff; }/* End custom CSS */