Provides mobile-first CSS patterns for responsive sales funnels including breakpoints, grid layouts, sticky CTAs, typography scales, touch targets, and viewport meta tags. Use for mobile-optimized pages.
npx claudepluginhub ominou5/funnel-architect-pluginThis skill uses the workspace's default tool permissions.
Over 60% of funnel traffic comes from mobile. Build mobile-first, always.
Designs adaptive layouts and interactions for all screen sizes, input methods, and devices using breakpoints, fluid scaling, patterns, and accessibility checks.
Guides mobile-first responsive UI layouts with CSS media queries, flexbox/grid, relative units (rem/em/% ), standard breakpoints, touch targets, and image optimization for all devices.
Designs responsive web interfaces using mobile-first CSS with media queries, touch-friendly elements, progressive enhancement, and performance guidelines for mobile-optimized sites.
Share bugs, ideas, or general feedback.
Over 60% of funnel traffic comes from mobile. Build mobile-first, always.
/* Mobile-first: base styles are for mobile */
/* Tablet */
@media (min-width: 768px) { /* ... */ }
/* Desktop */
@media (min-width: 1024px) { /* ... */ }
/* Large desktop */
@media (min-width: 1280px) { /* ... */ }
Every HTML page must include:
<meta name="viewport" content="width=device-width, initial-scale=1.0">
.container {
width: 100%;
max-width: 1200px;
margin: 0 auto;
padding: 0 16px;
}
/* Stack everything on mobile */
.grid {
display: grid;
grid-template-columns: 1fr;
gap: 24px;
}
@media (min-width: 768px) {
.grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
.grid { grid-template-columns: repeat(3, 1fr); }
}
.mobile-cta-bar {
display: none;
}
@media (max-width: 767px) {
.mobile-cta-bar {
display: flex;
position: fixed;
bottom: 0;
left: 0;
right: 0;
padding: 12px 16px;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
z-index: 100;
}
.mobile-cta-bar .cta-primary {
width: 100%;
min-height: 48px;
font-size: 16px;
}
/* Prevent content overlap with sticky bar */
body { padding-bottom: 80px; }
}
:root {
/* Mobile-first sizes */
--text-xs: 0.75rem; /* 12px */
--text-sm: 0.875rem; /* 14px */
--text-base: 1rem; /* 16px — minimum for body */
--text-lg: 1.125rem; /* 18px */
--text-xl: 1.25rem; /* 20px */
--text-2xl: 1.5rem; /* 24px */
--text-3xl: 1.875rem; /* 30px */
--text-4xl: 2.25rem; /* 36px */
}
h1 {
font-size: var(--text-3xl);
line-height: 1.2;
}
@media (min-width: 768px) {
h1 { font-size: var(--text-4xl); }
}
@media (min-width: 1024px) {
h1 { font-size: 3rem; /* 48px */ }
}
body {
font-size: var(--text-base); /* Never below 16px — prevents iOS zoom */
line-height: 1.6;
}
/* Minimum 44x44px for all interactive elements */
button, a, input, select, textarea {
min-height: 44px;
min-width: 44px;
}
/* Adequate spacing between tap targets */
.nav-links a {
padding: 12px 16px;
}
.form-group + .form-group {
margin-top: 16px;
}
img {
max-width: 100%;
height: auto;
display: block;
}