20 CSS Responsive Navbar Designs 16 / 20
CSS Floating Island Multi-Segment Navbar
Detached floating pill navbar with three independently styled segments for branding, links, and actions.
The code
<div class="nav-16">
<div class="nav-16__island">
<a href="#" class="nav-16__logo">
<div class="nav-16__logo-badge"></div>
Canopy
</a>
</div>
<div class="nav-16__island">
<ul class="nav-16__links">
<li><a href="#" class="is-active">Explore</a></li>
<li><a href="#">Products</a></li>
<li><a href="#">Sustainability</a></li>
<li><a href="#">Journal</a></li>
<li><a href="#">About</a></li>
</ul>
</div>
<div class="nav-16__island nav-16__cta-island">
<span class="nav-16__cta-text">Join 12k+ members</span>
<button class="nav-16__cta-btn">Get started</button>
</div>
</div>
<input type="checkbox" id="nav-16-toggle">
<div class="nav-16__mobile-bar">
<a href="#" class="nav-16__mobile-logo">
<div style="width:8px;height:8px;border-radius:50%;background:#6abf40;"></div>
Canopy
</a>
<label for="nav-16-toggle" class="nav-16__hamburger" aria-label="Toggle menu">
<span></span><span></span><span></span>
</label>
</div>
<div class="nav-16__mobile-menu">
<a href="#">Explore</a>
<a href="#">Products</a>
<a href="#">Sustainability</a>
<a href="#">Journal</a>
<a href="#">About</a>
<a href="#" style="color:#4a8c2a; font-weight:700; margin-top:0.25rem;">Get started →</a>
</div>
<div style="padding:4rem 2rem; max-width:700px; margin:0 auto;">
<h1 style="font-size:2.5rem; font-weight:800; letter-spacing:-0.04em; margin-bottom:1rem; color:#1c2b0e;">Floating Island Multi-Segment Navbar</h1>
<p style="color:#5a7040; font-size:1.05rem; line-height:1.75;">Three separate floating pill-shaped islands: logo, nav links, and CTA. Each uses <code>backdrop-filter</code> glass effect independently. The islands sit inside a flex row with <code>justify-content: space-between</code>.</p>
</div> <div class="nav-16">
<div class="nav-16__island">
<a href="#" class="nav-16__logo">
<div class="nav-16__logo-badge"></div>
Canopy
</a>
</div>
<div class="nav-16__island">
<ul class="nav-16__links">
<li><a href="#" class="is-active">Explore</a></li>
<li><a href="#">Products</a></li>
<li><a href="#">Sustainability</a></li>
<li><a href="#">Journal</a></li>
<li><a href="#">About</a></li>
</ul>
</div>
<div class="nav-16__island nav-16__cta-island">
<span class="nav-16__cta-text">Join 12k+ members</span>
<button class="nav-16__cta-btn">Get started</button>
</div>
</div>
<input type="checkbox" id="nav-16-toggle">
<div class="nav-16__mobile-bar">
<a href="#" class="nav-16__mobile-logo">
<div style="width:8px;height:8px;border-radius:50%;background:#6abf40;"></div>
Canopy
</a>
<label for="nav-16-toggle" class="nav-16__hamburger" aria-label="Toggle menu">
<span></span><span></span><span></span>
</label>
</div>
<div class="nav-16__mobile-menu">
<a href="#">Explore</a>
<a href="#">Products</a>
<a href="#">Sustainability</a>
<a href="#">Journal</a>
<a href="#">About</a>
<a href="#" style="color:#4a8c2a; font-weight:700; margin-top:0.25rem;">Get started →</a>
</div>
<div style="padding:4rem 2rem; max-width:700px; margin:0 auto;">
<h1 style="font-size:2.5rem; font-weight:800; letter-spacing:-0.04em; margin-bottom:1rem; color:#1c2b0e;">Floating Island Multi-Segment Navbar</h1>
<p style="color:#5a7040; font-size:1.05rem; line-height:1.75;">Three separate floating pill-shaped islands: logo, nav links, and CTA. Each uses <code>backdrop-filter</code> glass effect independently. The islands sit inside a flex row with <code>justify-content: space-between</code>.</p>
</div>.nav-16, .nav-16 *, .nav-16 *::before, .nav-16 *::after {
margin: 0; padding: 0; box-sizing: border-box;
}
.nav-16 {
--text: #1c2b0e;
--muted: rgba(28,43,14,0.45);
--accent: #4a8c2a;
--bg: rgba(255,255,255,0.85);
--border: rgba(28,43,14,0.1);
font-family: 'Plus Jakarta Sans', sans-serif;
padding: 1.25rem 1.5rem;
position: sticky; top: 0; z-index: 100;
display: flex; align-items: center; justify-content: space-between;
gap: 1rem;
}
/* Each section is its own floating island */
.nav-16__island {
background: var(--bg);
backdrop-filter: blur(20px) saturate(160%);
border: 1px solid var(--border);
border-radius: 999px;
box-shadow: 0 4px 24px rgba(0,0,0,0.08), 0 1px 0 rgba(255,255,255,0.6) inset;
display: flex; align-items: center;
}
.nav-16__logo {
font-weight: 800; font-size: 1rem; color: var(--text);
text-decoration: none; letter-spacing: -0.02em;
padding: 0.6rem 1.3rem;
display: flex; align-items: center; gap: 8px;
}
.nav-16__logo-badge {
width: 8px; height: 8px; border-radius: 50%;
background: #6abf40;
box-shadow: 0 0 0 3px rgba(106,191,64,0.2);
}
.nav-16__links {
display: flex; list-style: none; gap: 0;
padding: 0.35rem;
}
.nav-16__links a {
display: block; color: var(--muted); text-decoration: none;
font-size: 0.85rem; font-weight: 600;
padding: 0.45rem 0.9rem; border-radius: 999px;
transition: color 0.2s, background 0.2s;
white-space: nowrap;
}
.nav-16__links a:hover { color: var(--text); background: rgba(74,140,42,0.08); }
.nav-16__links a.is-active { color: var(--accent); background: rgba(74,140,42,0.12); }
.nav-16__cta-island { gap: 0.5rem; padding: 0.35rem 0.35rem 0.35rem 1rem; }
.nav-16__cta-text { font-size: 0.8rem; font-weight: 600; color: var(--muted); white-space: nowrap; }
.nav-16__cta-btn {
padding: 0.5rem 1.1rem; border-radius: 999px;
font-size: 0.85rem; font-weight: 700;
cursor: pointer; border: none; font-family: inherit;
background: var(--accent); color: #fff;
transition: background 0.2s, transform 0.15s;
box-shadow: 0 2px 8px rgba(74,140,42,0.35);
}
.nav-16__cta-btn:hover { background: #3a6e20; transform: scale(0.97); }
/* Mobile */
#nav-16-toggle { display: none; }
.nav-16__mobile-bar {
display: none; position: sticky; top: 0; z-index: 100;
padding: 1rem 1.25rem;
align-items: center; justify-content: space-between;
}
.nav-16__mobile-logo { font-weight: 800; font-size: 1rem; color: #1c2b0e; text-decoration: none; display: flex; align-items: center; gap: 8px; }
.nav-16__hamburger {
display: flex; flex-direction: column; gap: 5px; cursor: pointer;
padding: 0.5rem 0.75rem; border: none;
background: rgba(255,255,255,0.85); border-radius: 999px;
border: 1px solid rgba(28,43,14,0.1);
backdrop-filter: blur(12px);
}
.nav-16__hamburger span { display: block; width: 18px; height: 1.5px; background: #1c2b0e; border-radius: 2px; transition: transform 0.3s, opacity 0.3s; }
#nav-16-toggle:checked ~ .nav-16__mobile-bar .nav-16__hamburger span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
#nav-16-toggle:checked ~ .nav-16__mobile-bar .nav-16__hamburger span:nth-child(2) { opacity: 0; }
#nav-16-toggle:checked ~ .nav-16__mobile-bar .nav-16__hamburger span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
.nav-16__mobile-menu {
display: none; flex-direction: column; gap: 0.25rem;
background: rgba(255,255,255,0.9); backdrop-filter: blur(20px);
margin: 0 1.25rem; border-radius: 16px;
padding: 0.75rem 0.75rem 1rem;
border: 1px solid rgba(28,43,14,0.1);
box-shadow: 0 4px 24px rgba(0,0,0,0.08);
position: sticky; top: 70px; z-index: 99;
}
.nav-16__mobile-menu a { display: block; color: rgba(28,43,14,0.6); text-decoration: none; font-size: 0.9rem; font-weight: 600; padding: 0.6rem 0.75rem; border-radius: 10px; transition: background 0.15s, color 0.15s; }
.nav-16__mobile-menu a:hover { background: rgba(74,140,42,0.08); color: #4a8c2a; }
#nav-16-toggle:checked ~ .nav-16__mobile-menu { display: flex; }
@media (max-width: 768px) {
.nav-16 { display: none; }
.nav-16__mobile-bar { display: flex; }
}
@media (prefers-reduced-motion: reduce) {
.nav-16__links a, .nav-16__cta-btn { transition: none; }
.nav-16__hamburger span { transition: none; }
} .nav-16, .nav-16 *, .nav-16 *::before, .nav-16 *::after {
margin: 0; padding: 0; box-sizing: border-box;
}
.nav-16 {
--text: #1c2b0e;
--muted: rgba(28,43,14,0.45);
--accent: #4a8c2a;
--bg: rgba(255,255,255,0.85);
--border: rgba(28,43,14,0.1);
font-family: 'Plus Jakarta Sans', sans-serif;
padding: 1.25rem 1.5rem;
position: sticky; top: 0; z-index: 100;
display: flex; align-items: center; justify-content: space-between;
gap: 1rem;
}
/* Each section is its own floating island */
.nav-16__island {
background: var(--bg);
backdrop-filter: blur(20px) saturate(160%);
border: 1px solid var(--border);
border-radius: 999px;
box-shadow: 0 4px 24px rgba(0,0,0,0.08), 0 1px 0 rgba(255,255,255,0.6) inset;
display: flex; align-items: center;
}
.nav-16__logo {
font-weight: 800; font-size: 1rem; color: var(--text);
text-decoration: none; letter-spacing: -0.02em;
padding: 0.6rem 1.3rem;
display: flex; align-items: center; gap: 8px;
}
.nav-16__logo-badge {
width: 8px; height: 8px; border-radius: 50%;
background: #6abf40;
box-shadow: 0 0 0 3px rgba(106,191,64,0.2);
}
.nav-16__links {
display: flex; list-style: none; gap: 0;
padding: 0.35rem;
}
.nav-16__links a {
display: block; color: var(--muted); text-decoration: none;
font-size: 0.85rem; font-weight: 600;
padding: 0.45rem 0.9rem; border-radius: 999px;
transition: color 0.2s, background 0.2s;
white-space: nowrap;
}
.nav-16__links a:hover { color: var(--text); background: rgba(74,140,42,0.08); }
.nav-16__links a.is-active { color: var(--accent); background: rgba(74,140,42,0.12); }
.nav-16__cta-island { gap: 0.5rem; padding: 0.35rem 0.35rem 0.35rem 1rem; }
.nav-16__cta-text { font-size: 0.8rem; font-weight: 600; color: var(--muted); white-space: nowrap; }
.nav-16__cta-btn {
padding: 0.5rem 1.1rem; border-radius: 999px;
font-size: 0.85rem; font-weight: 700;
cursor: pointer; border: none; font-family: inherit;
background: var(--accent); color: #fff;
transition: background 0.2s, transform 0.15s;
box-shadow: 0 2px 8px rgba(74,140,42,0.35);
}
.nav-16__cta-btn:hover { background: #3a6e20; transform: scale(0.97); }
/* Mobile */
#nav-16-toggle { display: none; }
.nav-16__mobile-bar {
display: none; position: sticky; top: 0; z-index: 100;
padding: 1rem 1.25rem;
align-items: center; justify-content: space-between;
}
.nav-16__mobile-logo { font-weight: 800; font-size: 1rem; color: #1c2b0e; text-decoration: none; display: flex; align-items: center; gap: 8px; }
.nav-16__hamburger {
display: flex; flex-direction: column; gap: 5px; cursor: pointer;
padding: 0.5rem 0.75rem; border: none;
background: rgba(255,255,255,0.85); border-radius: 999px;
border: 1px solid rgba(28,43,14,0.1);
backdrop-filter: blur(12px);
}
.nav-16__hamburger span { display: block; width: 18px; height: 1.5px; background: #1c2b0e; border-radius: 2px; transition: transform 0.3s, opacity 0.3s; }
#nav-16-toggle:checked ~ .nav-16__mobile-bar .nav-16__hamburger span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
#nav-16-toggle:checked ~ .nav-16__mobile-bar .nav-16__hamburger span:nth-child(2) { opacity: 0; }
#nav-16-toggle:checked ~ .nav-16__mobile-bar .nav-16__hamburger span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
.nav-16__mobile-menu {
display: none; flex-direction: column; gap: 0.25rem;
background: rgba(255,255,255,0.9); backdrop-filter: blur(20px);
margin: 0 1.25rem; border-radius: 16px;
padding: 0.75rem 0.75rem 1rem;
border: 1px solid rgba(28,43,14,0.1);
box-shadow: 0 4px 24px rgba(0,0,0,0.08);
position: sticky; top: 70px; z-index: 99;
}
.nav-16__mobile-menu a { display: block; color: rgba(28,43,14,0.6); text-decoration: none; font-size: 0.9rem; font-weight: 600; padding: 0.6rem 0.75rem; border-radius: 10px; transition: background 0.15s, color 0.15s; }
.nav-16__mobile-menu a:hover { background: rgba(74,140,42,0.08); color: #4a8c2a; }
#nav-16-toggle:checked ~ .nav-16__mobile-menu { display: flex; }
@media (max-width: 768px) {
.nav-16 { display: none; }
.nav-16__mobile-bar { display: flex; }
}
@media (prefers-reduced-motion: reduce) {
.nav-16__links a, .nav-16__cta-btn { transition: none; }
.nav-16__hamburger span { transition: none; }
}How this works
Rather than a full-width bar, this navbar is a horizontally centered floating element with position: sticky; top: 1.5rem and a maximum width. The three segments — logo, links, actions — are separate divs with border-radius: 999px and individual background colours, arranged in a flex row with a gap between them. Each segment has its own shadow, making them feel like distinct cards floating above the page.
Customize
- Remove the gap between segments and unify the background for a single pill navbar variant.
- Add a
border: 1px solid rgba(255,255,255,0.1)to each segment for a subtle separation on dark backgrounds. - Make the floating effect more dramatic by increasing the
box-shadowspread and adding a slight backdrop blur. - On scroll, collapse the segment gap to zero using a JS-toggled class for a smooth island-to-bar transition.
Watch out for
- Sticky positioning on a centered element requires its parent to span the full page width and have a height greater than the viewport — otherwise sticky has nothing to stick within.
- The three-segment layout breaks at narrow widths before a hamburger menu kicks in — set a breakpoint well before the segments start touching.
Browser support
| Chrome | Safari | Firefox | Edge |
|---|---|---|---|
| 57+ | 10.1+ | 52+ | 57+ |
All features are modern baseline CSS. position: sticky works in all current browsers.
More from 20 CSS Responsive Navbar Designs
CSS Icon Dot Indicator NavbarCSS Step Progress Wizard NavbarCSS Vertical Rail Sidebar NavbarCSS Scroll-Aware Shrink NavbarCSS Breadcrumb Reading Progress NavbarCSS Full-Screen Overlay MenuCSS Morphing Search Expand NavbarCSS Announcement Bar Dual NavbarCSS Scroll Spy Active Highlight NavbarCSS Glassmorphism Frosted NavbarCSS Mega Menu Dropdown NavbarCSS Sidebar Drawer Navigation
View the full collection →