Tailwind CSS in Next.js — Complete Guide
Tailwind CSS in Next.js — Complete Guide: free step-by-step lesson with examples, common mistakes, and interview tips — part of Next.js Tutorial on Toolliyo Academy.
On this page
Next.js Tutorial (LearnHub) · Lesson 15 of 100
Tailwind CSS in Next.js
Beginner → Intermediate → Advanced → Professional
Beginner · 1 — Foundations · ~12 min read · Module 2: Layouts & Styling
Introduction
This lesson is part of the beginner section. We explain Tailwind CSS in Next.js slowly, with examples you can copy and run. If something is unclear, read it twice — that is how everyone learns. Tailwind is utility-first CSS. You compose classes like flex, gap-4, and text-slate-600 directly in JSX. create-next-app can install it automatically with PostCSS configured. LearnHub dashboards and catalogs need responsive grids fast. Tailwind avoids switching between files for every spacing tweak — common in startups and agencies.
Tailwind CSS in Next.js appears in almost every LearnHub page you will build. Once it clicks, data fetching and auth become much easier.
When will you use this?
You use layouts and styling in every page you build from your first screen to production.
- Course catalogs, lesson sidebars, and instructor dashboards all use layouts and shared navigation.
- When a student opens a lesson page, nested layouts keep the header and progress bar consistent.
Real-world: Practo-style clinic portal
The Healthcare team building Practo-style clinic portal uses Tailwind CSS in Next.js to build responsive LearnHub layouts quickly with utility classes. patients and doctors never see the TypeScript files — they just get a fast, reliable appointment booking and medical records UI.
Production-style code
export function CourseGrid({ courses }: { courses: { id: string; title: string }[] }) {
return (
<ul className="grid gap-4 sm:grid-cols-2 lg:grid-cols-3">
{courses.map((c) => (
<li key={c.id} className="rounded-lg border p-4 shadow-sm hover:shadow-md">
<h2 className="text-lg font-semibold text-slate-900">{c.title}</h2>
</li>
))}
</ul>
);
}
What happens in production: In Practo-style clinic portal, getting Tailwind CSS in Next.js right means patients and doctors trust the appointment booking and medical records UI every day.
Lesson example (start here)
Copy this smaller example first. Once it works, compare it with the real-world code above.
export function CourseGrid({ courses }: { courses: { id: string; title: string }[] }) {
return (
<ul className="grid gap-4 sm:grid-cols-2 lg:grid-cols-3">
{courses.map((c) => (
<li key={c.id} className="rounded-lg border p-4 shadow-sm hover:shadow-md">
<h2 className="text-lg font-semibold text-slate-900">{c.title}</h2>
</li>
))}
</ul>
);
}
Line-by-line walkthrough
| Code | What it means |
|---|---|
export function CourseGrid({ courses }: { courses: { id: string; title: string }[] }) { | Named export — reusable function or component. |
return ( | Returns JSX — what the user sees in the browser. |
<ul className="grid gap-4 sm:grid-cols-2 lg:grid-cols-3"> | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
{courses.map((c) => ( | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
<li key={c.id} className="rounded-lg border p-4 shadow-sm hover:shadow-md"> | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
<h2 className="text-lg font-semibold text-slate-900">{c.title}</h2> | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
</li> | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
))} | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
</ul> | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
); | Part of the Tailwind CSS in Next.js example — read it together with the lines before and after. |
} | Closes a block started by { above. |
How it works (big picture)
- sm: and lg: are responsive breakpoints.
- Utilities apply one concern each.
- tailwind.config content paths scan app/ and components/ for class names to include in the build.
Do this on your computer
- Confirm tailwind.config and globals.css @tailwind directives exist
- Build CourseGrid with grid and responsive columns
- Resize browser — watch columns change
- Extract repeated card classes to a component for DRY
- Read the real-world section and name which part of LearnHub uses this topic.
- Run the example locally with npm run dev and confirm the same behavior.
- Change one value in the example (route, text, or course id) and predict what will happen before you save.
Experiments — try changing this
- Change a string or route in the example and save — watch the browser update.
- Break the code on purpose (remove a bracket), read the error overlay, then fix it.
Remember
Utilities in className. Responsive prefixes sm: md: lg:. Configured by default with create-next-app.
Common questions
Tailwind vs Bootstrap?
Tailwind is utility-first; Bootstrap gives pre-built components. Both work with Next.js.
How long should I spend on Tailwind CSS in Next.js?
Until you can explain it in your own words and run the example without looking at the answer. Beginners often need 30–60 minutes per new concept; setup lessons may take one afternoon.
What if I get stuck on Tailwind CSS in Next.js?
Re-read the line-by-line walkthrough, check the terminal and browser overlay for errors, and compare your code character-by-character with the example. Search the exact error text — someone else had it too.
Where is Tailwind CSS in Next.js used in real jobs?
See the real-world section above — the same pattern appears in LMS, e-commerce, SaaS, and dashboards. Interviewers ask you to explain it using one concrete example.