Back to CSS Pricing Sections Highlighted Popular Pure CSS
Share
.ps-pop {
  padding: clamp(28px, 5vw, 56px) clamp(20px, 4vw, 40px);
  min-height: 480px;
  background: #1a1410;
  color: #fef2e6;
  font-family: 'Inter', system-ui, sans-serif;
}
.ps-pop-head { text-align: center; margin-bottom: clamp(28px, 5vw, 48px); }
.ps-pop-head h2 {
  font-size: clamp(24px, 3.6vw, 36px); font-weight: 700;
  letter-spacing: -0.02em; margin: 0 0 10px;
  background: linear-gradient(90deg, #ff8b5a, #ffb37a);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ps-pop-head p { color: #c9b3a3; margin: 0; font-size: 14px; }
.ps-pop-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px; align-items: center;
  max-width: 980px; margin: 0 auto;
}
.ps-pop-card {
  position: relative;
  background: #261c16;
  border: 1px solid rgba(255,179,122,0.12);
  border-radius: 16px;
  padding: 26px 22px 22px;
  display: flex; flex-direction: column;
}
.ps-pop-popular {
  background: linear-gradient(180deg, #ff8b5a 0%, #f56a3a 100%);
  color: #1a1410;
  transform: scale(1.05);
  box-shadow: 0 14px 40px rgba(245,106,58,0.35);
  border: 0;
  z-index: 2;
}
.ps-pop-badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: #1a1410; color: #ff8b5a;
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 5px 12px;
  border-radius: 999px;
}
.ps-pop-card h3 {
  font-size: 15px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; margin: 0 0 14px;
  color: #ffb37a;
}
.ps-pop-popular h3 { color: #1a1410; }
.ps-pop-price {
  display: flex; align-items: baseline; gap: 3px;
  margin-bottom: 6px;
}
.ps-pop-cur { font-size: 18px; font-weight: 600; opacity: 0.7; }
.ps-pop-amt { font-size: 44px; font-weight: 800; letter-spacing: -0.03em; }
.ps-pop-per { font-size: 13px; opacity: 0.7; margin-left: 4px; }
.ps-pop-sub { font-size: 13px; opacity: 0.75; margin: 0 0 18px; }
.ps-pop-feats {
  list-style: none; padding: 0; margin: 0 0 22px; flex: 1;
  font-size: 13.5px; line-height: 1.9;
}
.ps-pop-feats li::before {
  content: '✓'; display: inline-block; width: 18px;
  font-weight: 800; opacity: 0.85;
}
.ps-pop-cta {
  display: block; text-align: center;
  padding: 11px 16px; border-radius: 8px;
  text-decoration: none; font-size: 13.5px; font-weight: 600;
  border: 1px solid currentColor;
  color: #ffb37a; background: transparent;
  transition: background 0.18s, color 0.18s;
}
.ps-pop-cta:hover { background: #ffb37a; color: #1a1410; }
.ps-pop-cta-pri { background: #1a1410; color: #ff8b5a; border-color: #1a1410; }
.ps-pop-cta-pri:hover { background: #fef2e6; color: #1a1410; border-color: #fef2e6; }
.ps-pop-cta:focus-visible { outline: 2px solid #ff8b5a; outline-offset: 3px; }
@media (max-width: 820px) {
  .ps-pop-grid { grid-template-columns: 1fr; max-width: 380px; }
  .ps-pop-popular { transform: none; }
}
@media (prefers-reduced-motion: reduce) {
  .ps-pop-cta { transition: none; }
}
<section class="ps-pop" aria-label="Pricing">
  <header class="ps-pop-head">
    <h2>Simple pricing, no surprises.</h2>
    <p>Three plans. Same product. Pick what you can grow into.</p>
  </header>
  <div class="ps-pop-grid">
    <article class="ps-pop-card">
      <h3>Basic</h3>
      <div class="ps-pop-price">
        <span class="ps-pop-cur">$</span><span class="ps-pop-amt">12</span
        ><span class="ps-pop-per">/mo</span>
      </div>
      <p class="ps-pop-sub">Just the essentials.</p>
      <ul class="ps-pop-feats">
        <li>3 projects</li>
        <li>5 GB storage</li>
        <li>Email-only support</li>
      </ul>
      <a class="ps-pop-cta" href="#basic">Choose Basic</a>
    </article>
    <article class="ps-pop-card ps-pop-popular">
      <span class="ps-pop-badge" aria-label="Most popular plan">Most popular</span>
      <h3>Pro</h3>
      <div class="ps-pop-price">
        <span class="ps-pop-cur">$</span><span class="ps-pop-amt">36</span
        ><span class="ps-pop-per">/mo</span>
      </div>
      <p class="ps-pop-sub">Everything teams actually need.</p>
      <ul class="ps-pop-feats">
        <li>Unlimited projects</li>
        <li>100 GB storage</li>
        <li>Priority support</li>
        <li>Custom domains</li>
        <li>Team roles</li>
      </ul>
      <a class="ps-pop-cta ps-pop-cta-pri" href="#pro">Choose Pro</a>
    </article>
    <article class="ps-pop-card">
      <h3>Enterprise</h3>
      <div class="ps-pop-price">
        <span class="ps-pop-cur">$</span><span class="ps-pop-amt">99</span
        ><span class="ps-pop-per">/mo</span>
      </div>
      <p class="ps-pop-sub">Compliance + dedicated success.</p>
      <ul class="ps-pop-feats">
        <li>Everything in Pro</li>
        <li>SSO &amp; SAML</li>
        <li>SLA + dedicated CSM</li>
      </ul>
      <a class="ps-pop-cta" href="#enterprise">Contact sales</a>
    </article>
  </div>
</section>
Live preview Edit any tab — preview updates live Ready