npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

tailwind-clamp

v4.5.0

Published

Plugin to leverage the CSS clamp function in your Tailwind CSS project.

Downloads

16,187

Readme

Tailwind clamp

Fluid interfaces. From mobile to desktop.

Tailwind CSS plugin to build responsive interfaces that scale smoothly using CSS clamp() without breakpoint micromanagement.

Features

  • Clamp values between a min and max viewport width, making it grow / shrink with the viewport.
  • Possibility to use small to large, large to small, negative to positive, positive to negative and negative to negative values. (Negative values only work on properties that allow them, e.g. margin)
  • Supports px, rem and em units.
  • Supports text values with multiple properties (fontSize, lineHeight, letterSpacing). If lineHeight is definded as a unitless number or a calc() function, the resulting value is calculated and converted to the fontSize unit.
  • Supports using Tailwind CSS theme values, arbitrary values or a combination.
  • Supports container queries.
  • Supports CSS custom properties (--*) as the target property, to store clamp() values in variables for reuse.
  • Supports defining clamped theme variables via @theme { --clamp-*: start, end; }.

Requirements

The current version of the plugin is designed to be used with Tailwind version 4. To use it with version 3 use version 3.x.

Installation

Install the plugin from npm:

npm i tailwind-clamp

Add the plugin in your main CSS file:

@import "tailwindcss";
@plugin "tailwind-clamp";

Configuration

The plugin allows two configuration options:

| Name | Type | Description | Default value | | ------------- | ---------- | ------------------------------------- | ------------- | | minSize | {string} | Viewport size where the clamp starts. | 23.4375rem | | maxSize | {string} | Viewport size where the clamp end. | 90rem |

Value should be a css length (px, rem, em). The unit for both options need to match.

@import "tailwindcss";
@plugin "tailwind-clamp" {
  minSize: 25rem;
  maxSize: 80rem;
}

Usage

The plugin relies on the arbitrary values syntax clamp-[...]. You need to pass at least three arguments separated by commas without whitespace, optionally you can also pass the minSize and the maxSize:

clamp-[<property>,<start>,<end>,[minSize,maxSize]]

Arguments

  • property Property that the value should be applied to. See a list of all supported properties below.
  • start Value at minSize viewport size. It can be a key from your Tailwind CSS config file or a a css length (px, rem, em), the unit will need to match end.
  • end Value at maxSize viewport size. It can be a key from your Tailwind CSS config file or a css length (px, rem, em), the unit will need to match start.
  • [minSize=23.4375rem] Viewport or container size, where the clamp starts, defaults to 23.4375rem (375px). It can be a breakpoint or container size name from your theme or a css length (px, rem, em). Container size names and values are prefixed with @. The unit will need to match maxSize and be smaller than maxSize.
  • [maxSize=90rem] Viewport or container size, where the clamp stops, defaults to 90rem (1440px). It can be a breakpoint or container size name from your theme or a css length (px, rem, em). Container size names and values are prefixed with @. The unit will need to match minSize and be be larger than minSize.

Examples

<div class="clamp-[px,20,40] clamp-[py,10,18]">
  Add some fluid padding here.
</div>

<div class="@container">
  <div class="clamp-[text,lg,3xl,@sm,@5xl] clamp-[py,2,4,@29.5rem,@82rem]">
    Add some fluid typography and padding to the content of the container.
  </div>
</div>

Using a custom maxSize with the default minSize

If you only want to override maxSize while keeping the default minSize, you can leave the fourth argument empty:

<div class="clamp-[p,2,4,,md]">
  Padding scales from the default minSize (375px) up to the `md` breakpoint.
</div>

This is equivalent to writing clamp-[p,2,4,23.4375rem,md] but saves you from having to remember the default value.

Note on spacing and sizing properties

All spacing and sizing properties (p, m, w, etc.) accept unitless numbers and .5 floating numbers that will get multiplied by the --spacing variable, analog to how Tailwind CSS handles spacing values.

<div class="clamp-[p,1,2]">
  This will generate a `padding` value of `1rem` at `minSize` and `2rem` at `maxSize`.
</div>

Custom properties

You can use CSS custom properties (--*) as the target property to store a clamp() value in a CSS variable for reuse in calc() expressions or other properties.

clamp-[--variable-name,start,end]

[!NOTE] Only explicit CSS lengths (px, rem, em) are accepted as values — theme tokens and unitless numbers are not supported for custom properties.

Example

<body class="clamp-[--blockspace,2rem,6rem]">
  <header class="[--header-height:80px] fixed top-0">...</header>
  <section class="mt-[calc(var(--header-height)+var(--blockspace))]">
    Content with fluid spacing that accounts for the fixed header.
  </section>
</body>

Theme variables

You can define clamped values directly in your @theme block using the --clamp-* namespace. The plugin will compute the clamp() formula and inject the result as a CSS custom property.

@theme {
  --clamp-blockspace: 2rem, 6rem;
  --clamp-display: 2rem, 4rem;
}

You can also pass custom viewport breakpoints as the third and fourth values:

@theme {
  --clamp-narrow-space: 1rem, 3rem, 20rem, 80rem;
}

Theme clamp variables can be referenced by other theme variables. This lets you use computed clamp values for built-in Tailwind theme tokens like font sizes, spacing, and more:

@theme {
  --clamp-blockspace: 2rem, 6rem;
  --clamp-display: 2rem, 4rem;
  --font-size-display: var(--clamp-display);
  --spacing-section: var(--clamp-blockspace);
}

With the above theme, you can use the standard Tailwind utilities directly:

<h1 class="text-display">Fluid heading</h1>
<section class="p-section">Fluid padding from the theme</section>

You can also reference the clamp variables directly in utilities using the () shorthand syntax:

<section class="mt-(--clamp-blockspace)">
  Content with fluid spacing defined in the theme.
</section>

Or in custom CSS:

.hero {
  padding: var(--clamp-blockspace);
  font-size: var(--clamp-display);
}

[!NOTE] Only explicit CSS lengths (px, rem, em) are accepted — unitless numbers and theme tokens are not supported in theme variable definitions.

Supported properties

  • p including pt, pb, pl, pr, px, py, ps, pe, pbs, pbe.
  • m including mt, mb, ml, mr, mx, my, ms, me, mbs, mbe.
  • space-x and space-y
  • inset including inset-x, inset-y, inset-bs, inset-be.
  • top
  • left and start.
  • right and end.
  • bottom
  • text including font-size, line-height and letter-spacing if defined.
  • gap including gap-x, gap-y.
  • w and inline
  • h and block
  • size
  • min-w, min-h, min-inline, min-block
  • max-w, max-h, max-inline, max-block
  • basis
  • indent
  • rounded including rounded-s, rounded-ss, rounded-se, rounded-e, rounded-ee, rounded-es, rounded-t, rounded-r, rounded-b, rounded-l, rounded-tl, rounded-tr, rounded-bl, rounded-br.
  • translate-x and translate-y
  • text-stroke
  • stroke
  • leading
  • tracking
  • border including border-t, border-b, border-l, border-r, border-x, border-y, border-s, border-e, border-bs, border-be.
  • outline and outline-offset
  • scroll-m including scroll-mx, scroll-my, scroll-ms, scroll-me, scroll-mt, scroll-mb, scroll-ml, scroll-mr, scroll-mbs, scroll-mbe
  • scroll-p including scroll-px, scroll-py, scroll-ps, scroll-pe, scroll-pt, scroll-pb, scroll-pl, scroll-pr, scroll-pbs, scroll-pbe
  • decoration
  • underline-offset
  • --* (CSS custom properties)

Usage with tailwind-merge

If you use tailwind-merge to resolve conflicting Tailwind classes, install the tailwind-clamp-merge plugin so that clamp utilities are correctly merged with their static counterparts:

npm i tailwind-clamp-merge

const twMerge = extendTailwindMerge(withTailwindClamp);

This teaches tailwind-merge that clamp-[p,1,3] belongs to the same class group as p-4, so conflicts are resolved correctly:

twMerge('p-4 clamp-[p,1,3]')
// => 'clamp-[p,1,3]'

twMerge('clamp-[p,1,3] p-4')
// => 'p-4'

twMerge('text-lg clamp-[text,lg,3xl]')
// => 'clamp-[text,lg,3xl]'

// Hierarchical conflicts work too
twMerge('px-4 py-2 clamp-[p,1,3]')
// => 'clamp-[p,1,3]'

twMerge('w-4 h-8 clamp-[size,10,20]')
// => 'clamp-[size,10,20]'

All supported properties and their conflict hierarchies (e.g. p vs px/py, size vs w/h, rounded vs rounded-tl, border vs border-t) are handled automatically.

Credits & mentions

The plugin is based on the formula presented in this article.

See also fluid.tw by Max Barvian.

License

MIT