<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: ridbyte</title>
    <description>The latest articles on DEV Community by ridbyte (@ridbyte).</description>
    <link>https://dev.to/ridbyte</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3624473%2F81a8c475-6b60-42c9-9004-58b2e5b97b8c.png</url>
      <title>DEV Community: ridbyte</title>
      <link>https://dev.to/ridbyte</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/ridbyte"/>
    <language>en</language>
    <item>
      <title>Why You Should Always Prefix Tailwind in Embeddable Widgets</title>
      <dc:creator>ridbyte</dc:creator>
      <pubDate>Sat, 22 Nov 2025 15:53:33 +0000</pubDate>
      <link>https://dev.to/ridbyte/why-you-should-always-prefix-tailwind-in-embeddable-widgets-1m2f</link>
      <guid>https://dev.to/ridbyte/why-you-should-always-prefix-tailwind-in-embeddable-widgets-1m2f</guid>
      <description>&lt;h2&gt;
  
  
  Why You Should Always Prefix Tailwind in Embeddable Widgets
&lt;/h2&gt;

&lt;p&gt;I'm building CommentBy, a commenting widget that embeds anywhere with a single &lt;code&gt;&amp;lt;div&amp;gt;&lt;/code&gt; tag. I learned the hard way: &lt;strong&gt;if you use Tailwind in an embeddable widget, prefix your classes from day one.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Without prefixing, my widget's styles conflicted with every site that also used Tailwind. Buttons disappeared, layouts broke, some sites looked completely broken.&lt;/p&gt;

&lt;p&gt;Here's the problem and the fix.&lt;/p&gt;

&lt;h2&gt;
  
  
  The Problem with Unprefixed Tailwind in Widgets
&lt;/h2&gt;

&lt;p&gt;Your widget loads on someone else's site:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="c"&gt;&amp;lt;!-- User adds this to their site --&amp;gt;&lt;/span&gt;
        &lt;span class="nt"&gt;&amp;lt;div&lt;/span&gt; &lt;span class="na"&gt;id=&lt;/span&gt;&lt;span class="s"&gt;"commentby_comment_box"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
        &lt;span class="nt"&gt;&amp;lt;script &lt;/span&gt;&lt;span class="na"&gt;defer&lt;/span&gt; &lt;span class="na"&gt;src=&lt;/span&gt;&lt;span class="s"&gt;"https://cdn.commentby.com/widget.js"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&amp;lt;/script&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Your code renders HTML with Tailwind classes into their page. If they also use Tailwind, you have collision problems:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Scenario 1: Different theme configurations&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Their Tailwind defines &lt;code&gt;blue-500&lt;/code&gt; as &lt;code&gt;#1E40AF&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;Your Tailwind defines &lt;code&gt;blue-500&lt;/code&gt; as &lt;code&gt;#3B82F6&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;Result: Your blue buttons are the wrong shade of blue&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Scenario 2: Different Tailwind versions&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;They use Tailwind 2.x with different spacing scale&lt;/li&gt;
&lt;li&gt;You use Tailwind 3.x/4.x&lt;/li&gt;
&lt;li&gt;Result: Your &lt;code&gt;p-4&lt;/code&gt; has different padding than expected&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Scenario 3: Custom color palettes&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;They redefined &lt;code&gt;gray-100&lt;/code&gt; to be pink for their brand&lt;/li&gt;
&lt;li&gt;You use &lt;code&gt;bg-gray-100&lt;/code&gt; for comment cards&lt;/li&gt;
&lt;li&gt;Result: Pink comment cards&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Scenario 4: Global style overrides&lt;/strong&gt; (This was the worst)&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight css"&gt;&lt;code&gt;&lt;span class="c"&gt;/* Host site has this */&lt;/span&gt;
&lt;span class="nt"&gt;button&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;background&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;transparent&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="nl"&gt;border&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="m"&gt;2px&lt;/span&gt; &lt;span class="nb"&gt;solid&lt;/span&gt; &lt;span class="no"&gt;black&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="nl"&gt;font-weight&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;bold&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Your widget's &lt;code&gt;bg-blue-500&lt;/code&gt; button suddenly has transparent background because their global styles override your utilities (unless you use &lt;code&gt;!important&lt;/code&gt;).&lt;/p&gt;

&lt;h2&gt;
  
  
  Real Examples from CommentBy
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Tech blog (Next.js + Tailwind):&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Used custom gray palette&lt;/li&gt;
&lt;li&gt;Result: My light gray backgrounds became bright pink&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;WordPress site:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Theme had &lt;code&gt;button { all: unset; }&lt;/code&gt; reset&lt;/li&gt;
&lt;li&gt;Result: My submit button became invisible&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Ghost blog:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Used &lt;code&gt;!important&lt;/code&gt; on base text colors&lt;/li&gt;
&lt;li&gt;Result: All my text hierarchy broke&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Marketing site:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Had global &lt;code&gt;* { box-sizing: content-box; }&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;Result: All padding calculations broke, layout collapsed&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  The Solution: Prefix Everything
&lt;/h2&gt;

&lt;p&gt;Use Tailwind's prefix feature from day one:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight css"&gt;&lt;code&gt;&lt;span class="c"&gt;/* widget.css */&lt;/span&gt;
&lt;span class="k"&gt;@import&lt;/span&gt; &lt;span class="s1"&gt;"tailwindcss"&lt;/span&gt; &lt;span class="n"&gt;prefix&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;commentby&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="n"&gt;important&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Two directives:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;&lt;code&gt;prefix(commentby)&lt;/code&gt;&lt;/strong&gt; - All classes get &lt;code&gt;commentby:&lt;/code&gt; namespace&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;&lt;code&gt;important&lt;/code&gt;&lt;/strong&gt; - All utilities get &lt;code&gt;!important&lt;/code&gt; to override host styles&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Now your classes look like:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="c1"&gt;// Before (dangerous)&lt;/span&gt;
&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;div&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"bg-white p-4 rounded-lg shadow-md"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"bg-blue-500 px-6 py-2 text-white"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
    Submit
  &lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;div&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;

&lt;span class="c1"&gt;// After (safe)&lt;/span&gt;
&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;div&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"commentby:bg-white commentby:p-4 commentby:rounded-lg commentby:shadow-md"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"commentby:bg-blue-500 commentby:px-6 commentby:py-2 commentby:text-white"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
    Submit
  &lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;div&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Your &lt;code&gt;.commentby\:bg-blue-500&lt;/code&gt; won't conflict with their &lt;code&gt;.bg-blue-500&lt;/code&gt;.&lt;/p&gt;

&lt;h2&gt;
  
  
  How Prefix Works
&lt;/h2&gt;

&lt;p&gt;The prefix goes &lt;strong&gt;first&lt;/strong&gt;, before all modifiers:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;div&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="err"&gt;"&lt;/span&gt;
  &lt;span class="na"&gt;commentby&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;p-4&lt;/span&gt;
  &lt;span class="na"&gt;commentby&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;md&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;p-6&lt;/span&gt;
  &lt;span class="na"&gt;commentby&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;lg&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;p-8&lt;/span&gt;
  &lt;span class="na"&gt;commentby&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;hover&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;bg-blue-500&lt;/span&gt;
  &lt;span class="na"&gt;commentby&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;focus&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;ring-2&lt;/span&gt;
  &lt;span class="na"&gt;commentby&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;dark&lt;/span&gt;&lt;span class="err"&gt;:&lt;/span&gt;&lt;span class="na"&gt;bg-gray-800&lt;/span&gt;
&lt;span class="err"&gt;"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Not &lt;code&gt;md:commentby:p-6&lt;/code&gt; - the prefix is always first.&lt;/p&gt;

&lt;h2&gt;
  
  
  Generated CSS
&lt;/h2&gt;

&lt;p&gt;Tailwind compiles to:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight css"&gt;&lt;code&gt;&lt;span class="nc"&gt;.commentby&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:bg-blue-500&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;background-color&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;rgb&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="m"&gt;59&lt;/span&gt; &lt;span class="m"&gt;130&lt;/span&gt; &lt;span class="m"&gt;246&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="cp"&gt;!important&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="nc"&gt;.commentby&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:p-4&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;padding&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="m"&gt;1rem&lt;/span&gt; &lt;span class="cp"&gt;!important&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="k"&gt;@media&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;min-width&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="m"&gt;768px&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nc"&gt;.commentby&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:md&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:p-6&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="nl"&gt;padding&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="m"&gt;1.5rem&lt;/span&gt; &lt;span class="cp"&gt;!important&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="nc"&gt;.commentby&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:hover&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:bg-blue-600:hover&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;background-color&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;rgb&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="m"&gt;37&lt;/span&gt; &lt;span class="m"&gt;99&lt;/span&gt; &lt;span class="m"&gt;235&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="cp"&gt;!important&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Every utility gets:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Your prefix namespace (&lt;code&gt;.commentby\:&lt;/code&gt;)&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;!important&lt;/code&gt; flag&lt;/li&gt;
&lt;li&gt;Proper CSS escaping (&lt;code&gt;\:&lt;/code&gt; for colons)&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Why &lt;code&gt;important&lt;/code&gt; is Critical
&lt;/h2&gt;

&lt;p&gt;Without &lt;code&gt;!important&lt;/code&gt;, host page styles still win:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight css"&gt;&lt;code&gt;&lt;span class="c"&gt;/* Their site */&lt;/span&gt;
&lt;span class="nt"&gt;button&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;background&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;transparent&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="nl"&gt;padding&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="m"&gt;10px&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c"&gt;/* Your widget */&lt;/span&gt;
&lt;span class="nc"&gt;.commentby&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:bg-blue-500&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;background-color&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;rgb&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="m"&gt;59&lt;/span&gt; &lt;span class="m"&gt;130&lt;/span&gt; &lt;span class="m"&gt;246&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c"&gt;/* Lost - no !important */&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Global &lt;code&gt;button&lt;/code&gt; styles have higher specificity. Your button stays transparent.&lt;/p&gt;

&lt;p&gt;With &lt;code&gt;important&lt;/code&gt;, you win:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight css"&gt;&lt;code&gt;&lt;span class="nc"&gt;.commentby&lt;/span&gt;&lt;span class="err"&gt;\&lt;/span&gt;&lt;span class="nd"&gt;:bg-blue-500&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;background-color&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;rgb&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="m"&gt;59&lt;/span&gt; &lt;span class="m"&gt;130&lt;/span&gt; &lt;span class="m"&gt;246&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="cp"&gt;!important&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt; &lt;span class="c"&gt;/* Wins */&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Implementation with Preact
&lt;/h2&gt;

&lt;p&gt;Here's how I use it in CommentBy:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="c1"&gt;// Widget.jsx&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;render&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;preact&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;CommentWidget&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="k"&gt;return &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;div&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"commentby:bg-white commentby:p-6 commentby:rounded-lg commentby:shadow-lg"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
      &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;form&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"commentby:space-y-4"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
        &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;textarea&lt;/span&gt; 
          &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"commentby:w-full commentby:p-3 commentby:border commentby:rounded"&lt;/span&gt;
          &lt;span class="na"&gt;placeholder&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"Add a comment..."&lt;/span&gt;
        &lt;span class="p"&gt;/&amp;gt;&lt;/span&gt;
        &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt; 
          &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"commentby:bg-blue-500 commentby:text-white commentby:px-4 commentby:py-2 commentby:rounded commentby:hover:bg-blue-600"&lt;/span&gt;
        &lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
          Submit
        &lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
      &lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;form&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
    &lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;div&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// Mount to the page&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;container&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nb"&gt;document&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;getElementById&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;commentby-widget&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="nf"&gt;render&lt;/span&gt;&lt;span class="p"&gt;(&amp;lt;&lt;/span&gt;&lt;span class="nc"&gt;CommentWidget&lt;/span&gt; &lt;span class="p"&gt;/&amp;gt;,&lt;/span&gt; &lt;span class="nx"&gt;container&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;CSS gets bundled into the same file with Vite, so it's one JavaScript file with inlined styles.&lt;/p&gt;

&lt;h2&gt;
  
  
  Shadow DOM Alternative
&lt;/h2&gt;

&lt;p&gt;You could use Shadow DOM for complete isolation:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;container&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nb"&gt;document&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;getElementById&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;commentby-widget&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;shadowRoot&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;container&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;attachShadow&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt; &lt;span class="na"&gt;mode&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;open&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt; &lt;span class="p"&gt;});&lt;/span&gt;

&lt;span class="c1"&gt;// Render Preact into Shadow DOM&lt;/span&gt;
&lt;span class="nf"&gt;render&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;CommentWidget&lt;/span&gt; &lt;span class="o"&gt;/&amp;gt;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;shadowRoot&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;With Shadow DOM, you don't need prefix or &lt;code&gt;important&lt;/code&gt; - styles are fully isolated.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Why I didn't use Shadow DOM:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Can't inherit host site's font (looks disconnected)&lt;/li&gt;
&lt;li&gt;Can't inherit base text colors (feels like iframe)&lt;/li&gt;
&lt;li&gt;More complex event handling&lt;/li&gt;
&lt;li&gt;Accessibility concerns&lt;/li&gt;
&lt;li&gt;Want widget to feel integrated, not isolated&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The &lt;code&gt;prefix + important&lt;/code&gt; approach gives isolation where needed while allowing intentional inheritance.&lt;/p&gt;

&lt;h2&gt;
  
  
  Testing Strategy
&lt;/h2&gt;

&lt;p&gt;Test your widget on sites with different CSS:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;Tailwind site&lt;/strong&gt; (class conflicts)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Bootstrap site&lt;/strong&gt; (different utilities)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;WordPress with theme&lt;/strong&gt; (global button styles)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Ghost blog&lt;/strong&gt; (custom CSS)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Legacy site&lt;/strong&gt; (old CSS, weird resets)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Minimal site&lt;/strong&gt; (baseline)&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;For each, verify:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Layout integrity&lt;/li&gt;
&lt;li&gt;Colors match design&lt;/li&gt;
&lt;li&gt;Spacing correct&lt;/li&gt;
&lt;li&gt;Buttons render properly&lt;/li&gt;
&lt;li&gt;Responsive breakpoints work&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Performance
&lt;/h2&gt;

&lt;p&gt;Prefix adds minimal overhead:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Without prefix:&lt;/strong&gt; 45KB minified&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;With prefix + important:&lt;/strong&gt; 47KB minified&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The 2KB increase (just the prefix string repeated) is worth it for zero conflicts across any site.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I Wish I Knew
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Start with prefix from day one.&lt;/strong&gt; I had to refactor 150+ component files, updating every single className. It's tedious and error-prone.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Don't assume your test page represents real sites.&lt;/strong&gt; Clean HTML with no CSS is nothing like a production WordPress site with 15 plugins and aggressive theme styles.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Test early on real sites&lt;/strong&gt; with real CSS conflicts.&lt;/p&gt;

&lt;h2&gt;
  
  
  Conclusion
&lt;/h2&gt;

&lt;p&gt;If you're building embeddable widgets with Tailwind:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;Use prefix from day one:&lt;/strong&gt; &lt;code&gt;@import "tailwindcss" prefix(yourapp) important;&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Prefix syntax:&lt;/strong&gt; &lt;code&gt;yourapp:p-4&lt;/code&gt;, &lt;code&gt;yourapp:md:p-6&lt;/code&gt;, &lt;code&gt;yourapp:hover:bg-blue-500&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Always include &lt;code&gt;important&lt;/code&gt;&lt;/strong&gt; to override host styles&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Test on real sites early&lt;/strong&gt; (multiple CSS frameworks, versions, custom styles)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Consider Shadow DOM&lt;/strong&gt; only if you need total isolation&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Don't learn this the hard way like I did. Prefix from the start.&lt;/p&gt;




&lt;p&gt;&lt;strong&gt;Building CommentBy&lt;/strong&gt; - a privacy-first commenting widget that embeds anywhere. Built with Preact and properly prefixed Tailwind. &lt;a href="https://commentby.com" rel="noopener noreferrer"&gt;Try the demo&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;What's your experience with CSS conflicts in embeddable widgets? Drop a comment.&lt;/p&gt;

</description>
      <category>tailwindcss</category>
      <category>webdev</category>
      <category>frontend</category>
    </item>
  </channel>
</rss>
