CSS
/* ─── 11 Soft UI Form Controls — pure CSS showcase ───────────────── */
@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@300;400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap');
.nm-ctl {
--nm-ctl-bg: #f0ebe2;
--nm-ctl-sd: #d0cbbf;
--nm-ctl-sl: #fffdf8;
--nm-ctl-ib: #e8e2d8;
--nm-ctl-acc: #5c6bc0;
--nm-ctl-ac2: #8c9ce0;
--nm-ctl-ac3: #3a4a9a;
--nm-ctl-grn: #4a8a68;
--nm-ctl-txt: #6a6258;
--nm-ctl-txt2:#1a1510;
--nm-ctl-neu-sm: 5px 5px 12px var(--nm-ctl-sd), -5px -5px 12px var(--nm-ctl-sl);
--nm-ctl-neu-sm-in: inset 4px 4px 9px var(--nm-ctl-sd), inset -4px -4px 9px var(--nm-ctl-sl);
position: relative;
width: 100%;
min-height: 880px;
background: var(--nm-ctl-bg);
font-family: 'Raleway', system-ui, sans-serif;
color: var(--nm-ctl-txt);
display: flex;
align-items: center;
justify-content: center;
padding: 32px 16px;
overflow: hidden;
box-sizing: border-box;
}
.nm-ctl *,
.nm-ctl *::before,
.nm-ctl *::after { box-sizing: border-box; }
.nm-ctl .card {
position: relative;
width: 100%;
max-width: 860px;
background: var(--nm-ctl-bg);
border-radius: 40px;
padding: 40px 36px;
box-shadow: 20px 20px 50px var(--nm-ctl-sd), -20px -20px 50px var(--nm-ctl-sl);
display: flex;
flex-direction: column;
gap: 32px;
}
.nm-ctl .sec { display: flex; flex-direction: column; gap: 16px; }
.nm-ctl .sec-head { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.nm-ctl .sec-title { font-size: 14px; font-weight: 800; color: var(--nm-ctl-txt2); letter-spacing: 0.3px; }
.nm-ctl .sec-tag {
font-family: 'DM Mono', ui-monospace, monospace;
font-size: 9px;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--nm-ctl-txt);
opacity: 0.5;
}
.nm-ctl .sub-tag {
font-family: 'DM Mono', ui-monospace, monospace;
font-size: 9px;
letter-spacing: 2px;
text-transform: uppercase;
color: var(--nm-ctl-txt);
opacity: 0.5;
margin-bottom: 4px;
}
.nm-ctl .controls-row { display: flex; gap: 22px; align-items: flex-start; flex-wrap: wrap; }
.nm-ctl .col-stack { display: flex; flex-direction: column; gap: 12px; }
.nm-ctl .col-stack-flex { flex: 1; min-width: 180px; }
.nm-ctl .div-line {
height: 1px;
background: linear-gradient(to right, transparent, var(--nm-ctl-sd), transparent);
opacity: 0.5;
}
/* Style A — Classic radio */
.nm-ctl .radio-classic { display: flex; flex-direction: column; gap: 12px; min-width: 160px; }
.nm-ctl .rc-item {
display: flex;
align-items: center;
gap: 13px;
cursor: pointer;
user-select: none;
}
.nm-ctl .rc-input { position: absolute; opacity: 0; pointer-events: none; }
.nm-ctl .rc-circle {
width: 26px;
height: 26px;
border-radius: 50%;
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm-in);
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
transition: box-shadow 0.2s ease;
position: relative;
}
.nm-ctl .rc-circle::after {
content: '';
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) scale(0);
width: 11px;
height: 11px;
border-radius: 50%;
background: var(--nm-ctl-acc);
box-shadow: 0 0 8px rgba(92, 107, 192, 0.5);
transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.nm-ctl .rc-input:checked ~ .rc-circle::after { transform: translate(-50%, -50%) scale(1); }
.nm-ctl .rc-input:checked ~ .rc-circle { box-shadow: var(--nm-ctl-neu-sm); }
.nm-ctl .rc-label {
display: flex;
flex-direction: column;
font-size: 13px;
font-weight: 600;
color: var(--nm-ctl-txt2);
transition: color 0.2s;
line-height: 1.3;
}
.nm-ctl .rc-item:hover .rc-label { color: var(--nm-ctl-acc); }
.nm-ctl .rc-sublabel { font-size: 10px; color: var(--nm-ctl-txt); font-weight: 400; margin-top: 1px; }
/* Style B — Pill group */
.nm-ctl .pill-group {
display: flex;
background: var(--nm-ctl-ib);
border-radius: 20px;
padding: 5px;
box-shadow: var(--nm-ctl-neu-sm-in);
gap: 4px;
}
.nm-ctl .pill-input { position: absolute; opacity: 0; pointer-events: none; }
.nm-ctl .pill-label {
flex: 1;
padding: 9px 14px;
border-radius: 15px;
font-size: 12px;
font-weight: 700;
color: var(--nm-ctl-txt);
cursor: pointer;
text-align: center;
transition: all 0.22s cubic-bezier(0.4, 0, 0.2, 1);
white-space: nowrap;
}
.nm-ctl .pill-input:checked + .pill-label {
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm);
color: var(--nm-ctl-acc);
}
.nm-ctl .pill-group-v {
display: flex;
flex-direction: column;
background: var(--nm-ctl-ib);
border-radius: 18px;
padding: 5px;
box-shadow: var(--nm-ctl-neu-sm-in);
gap: 4px;
min-width: 160px;
}
.nm-ctl .pill-label-v {
padding: 9px 14px;
border-radius: 13px;
font-size: 12px;
font-weight: 700;
color: var(--nm-ctl-txt);
cursor: pointer;
transition: all 0.22s;
display: flex;
align-items: center;
gap: 10px;
}
.nm-ctl .pill-input:checked + .pill-label-v {
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm);
color: var(--nm-ctl-acc);
}
.nm-ctl .pill-icon { font-size: 16px; }
/* Style C — Card radio */
.nm-ctl .card-radio-group { display: flex; gap: 12px; flex-wrap: wrap; }
.nm-ctl .card-input { position: absolute; opacity: 0; pointer-events: none; }
.nm-ctl .card-label {
flex: 1;
background: var(--nm-ctl-bg);
border-radius: 18px;
padding: 16px 12px;
box-shadow: var(--nm-ctl-neu-sm);
cursor: pointer;
display: flex;
flex-direction: column;
align-items: center;
gap: 6px;
transition: all 0.22s ease;
min-width: 100px;
position: relative;
}
.nm-ctl .card-label:hover {
transform: translateY(-2px);
box-shadow: 8px 8px 20px var(--nm-ctl-sd), -8px -8px 20px var(--nm-ctl-sl);
}
.nm-ctl .card-input:checked + .card-label { box-shadow: var(--nm-ctl-neu-sm-in); }
.nm-ctl .card-label::before {
content: '';
position: absolute;
top: 10px;
right: 10px;
width: 18px;
height: 18px;
border-radius: 50%;
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm-in);
transition: all 0.2s;
}
.nm-ctl .card-input:checked + .card-label::before {
background: var(--nm-ctl-acc);
box-shadow: 0 0 8px rgba(92, 107, 192, 0.4);
}
.nm-ctl .card-label::after {
content: '';
position: absolute;
top: 14px;
right: 14px;
width: 10px;
height: 10px;
border-radius: 50%;
background: #fff;
transform: scale(0);
transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.nm-ctl .card-input:checked + .card-label::after { transform: scale(1); }
.nm-ctl .card-icon { font-size: 24px; }
.nm-ctl .card-title { font-size: 12px; font-weight: 800; color: var(--nm-ctl-txt2); letter-spacing: 0.3px; }
.nm-ctl .card-desc { font-size: 10px; color: var(--nm-ctl-txt); text-align: center; line-height: 1.4; }
.nm-ctl .card-price {
font-family: 'DM Mono', ui-monospace, monospace;
font-size: 13px;
font-weight: 700;
color: var(--nm-ctl-acc);
margin-top: 2px;
}
/* Checkboxes Style A — classic box */
.nm-ctl .check-classic { display: flex; flex-direction: column; gap: 12px; min-width: 180px; }
.nm-ctl .cb-item {
display: flex;
align-items: center;
gap: 13px;
cursor: pointer;
user-select: none;
}
.nm-ctl .cb-input { position: absolute; opacity: 0; pointer-events: none; }
.nm-ctl .cb-box {
width: 24px;
height: 24px;
border-radius: 8px;
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm-in);
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
transition: all 0.2s ease;
overflow: hidden;
position: relative;
}
.nm-ctl .cb-check {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
transform: scale(0) rotate(20deg);
transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.nm-ctl .cb-check::before {
content: '';
width: 5px;
height: 9px;
border-right: 2.5px solid #fff;
border-bottom: 2.5px solid #fff;
transform: rotate(45deg);
margin-top: -4px;
}
.nm-ctl .cb-input:checked ~ .cb-box {
background: linear-gradient(145deg, var(--nm-ctl-acc), var(--nm-ctl-ac3));
box-shadow: 3px 3px 8px rgba(92, 107, 192, 0.35), -2px -2px 6px var(--nm-ctl-sl);
}
.nm-ctl .cb-input:checked ~ .cb-box .cb-check { transform: scale(1) rotate(0deg); }
.nm-ctl .cb-txt {
font-size: 13px;
font-weight: 600;
color: var(--nm-ctl-txt2);
transition: color 0.2s;
line-height: 1.3;
}
.nm-ctl .cb-item:hover .cb-txt { color: var(--nm-ctl-acc); }
/* Checkboxes Style B — stamp pill */
.nm-ctl .stamp-group { display: flex; gap: 10px; flex-wrap: wrap; }
.nm-ctl .stamp-input { position: absolute; opacity: 0; pointer-events: none; }
.nm-ctl .stamp-label {
padding: 9px 16px;
border-radius: 100px;
font-size: 12px;
font-weight: 700;
color: var(--nm-ctl-txt);
cursor: pointer;
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm);
transition: all 0.2s ease;
display: inline-flex;
align-items: center;
gap: 7px;
user-select: none;
}
.nm-ctl .stamp-label:hover { transform: translateY(-1px); color: var(--nm-ctl-acc); }
.nm-ctl .stamp-input:checked + .stamp-label {
box-shadow: var(--nm-ctl-neu-sm-in);
color: var(--nm-ctl-acc);
font-weight: 800;
}
.nm-ctl .stamp-tick {
width: 16px;
height: 16px;
border-radius: 50%;
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm-in);
display: inline-flex;
align-items: center;
justify-content: center;
transition: all 0.2s;
flex-shrink: 0;
}
.nm-ctl .stamp-input:checked + .stamp-label .stamp-tick {
background: var(--nm-ctl-acc);
box-shadow: 0 0 6px rgba(92, 107, 192, 0.4);
color: #fff;
font-size: 10px;
}
.nm-ctl .stamp-input:checked + .stamp-label .stamp-tick::after { content: '\2713'; }
/* Checkboxes Style C — card check */
.nm-ctl .card-check-group { display: flex; flex-direction: column; gap: 10px; min-width: 240px; }
.nm-ctl .cc-input { position: absolute; opacity: 0; pointer-events: none; }
.nm-ctl .cc-label {
background: var(--nm-ctl-bg);
border-radius: 16px;
padding: 13px 16px;
box-shadow: var(--nm-ctl-neu-sm);
cursor: pointer;
display: flex;
align-items: center;
gap: 14px;
transition: all 0.2s;
user-select: none;
}
.nm-ctl .cc-label:hover { box-shadow: 7px 7px 16px var(--nm-ctl-sd), -7px -7px 16px var(--nm-ctl-sl); }
.nm-ctl .cc-input:checked + .cc-label { box-shadow: var(--nm-ctl-neu-sm-in); }
.nm-ctl .cc-sq {
width: 22px;
height: 22px;
border-radius: 7px;
background: var(--nm-ctl-bg);
box-shadow: var(--nm-ctl-neu-sm-in);
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
transition: all 0.2s;
position: relative;
overflow: hidden;
}
.nm-ctl .cc-input:checked + .cc-label .cc-sq {
background: linear-gradient(145deg, var(--nm-ctl-grn), #2a6a48);
box-shadow: 2px 2px 6px rgba(74, 138, 104, 0.4);
}
.nm-ctl .cc-sq-inner {
transform: scale(0);
transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
font-size: 12px;
color: #fff;
}
.nm-ctl .cc-input:checked + .cc-label .cc-sq-inner { transform: scale(1); }
.nm-ctl .cc-text {
flex: 1;
display: flex;
flex-direction: column;
}
.nm-ctl .cc-name { font-size: 13px; font-weight: 700; color: var(--nm-ctl-txt2); }
.nm-ctl .cc-detail { font-size: 10px; color: var(--nm-ctl-txt); margin-top: 2px; }
.nm-ctl .cc-badge {
font-family: 'DM Mono', ui-monospace, monospace;
font-size: 10px;
font-weight: 700;
color: var(--nm-ctl-txt);
padding: 3px 8px;
background: var(--nm-ctl-ib);
border-radius: 8px;
box-shadow: var(--nm-ctl-neu-sm-in);
}
@media (prefers-reduced-motion: reduce) {
.nm-ctl .rc-circle::after,
.nm-ctl .pill-label,
.nm-ctl .pill-label-v,
.nm-ctl .card-label,
.nm-ctl .card-label::after,
.nm-ctl .cb-box,
.nm-ctl .cb-check,
.nm-ctl .stamp-label,
.nm-ctl .cc-label,
.nm-ctl .cc-sq-inner { transition: none; animation: none; }
}