color-picker/color.css

1452 lines
27 KiB
CSS

:root {
--bpb-bg: #efe8d7;
--bpb-bg-2: #f8f5ea;
--bpb-panel: rgba(255, 253, 247, 0.92);
--bpb-panel-strong: #fffdf7;
--bpb-border: #e4dbc1;
--bpb-border-strong: #d7cbab;
--bpb-text: #183348;
--bpb-muted: #5f6f78;
--bpb-accent: #0ea7a0;
--bpb-accent-strong: #0a7f7b;
--bpb-shadow: 0 12px 28px rgba(28, 40, 64, 0.1);
--bpb-shadow-strong: 0 18px 38px rgba(28, 40, 64, 0.16);
--radius-lg: 18px;
--radius-md: 14px;
--radius-sm: 10px;
--compare-bg: #e2e5e8;
--compare-bg-2: #d8dde2;
--compare-border: #bfc7cf;
--swatch-w: 108px;
--swatch-h: 148px;
--palette-swatch-w: 90px;
--palette-swatch-h: 124px;
--string-top: 88px;
--palette-string-top: 72px;
}
*,
*::before,
*::after {
box-sizing: border-box;
}
html,
body {
margin: 0;
min-height: 100%;
}
body {
font-family: "Autour One", serif;
color: var(--bpb-text);
background:
radial-gradient(circle at 12% 12%, rgba(255, 248, 221, 0.95), rgba(255, 248, 221, 0) 42%),
radial-gradient(circle at 88% 2%, rgba(14, 167, 160, 0.12), rgba(14, 167, 160, 0) 28%),
linear-gradient(180deg, #f4efdf 0%, var(--bpb-bg) 36%, #ebe3cf 100%);
}
body.modal-open {
overflow: hidden;
overscroll-behavior: none;
}
body.modal-open > *:not(.palette-modal-backdrop):not(.preset-modal-backdrop):not(#zoom-overlay):not(script) {
pointer-events: none;
}
.navbar {
background: rgba(14, 167, 160, 0.94) !important;
backdrop-filter: blur(6px);
}
.navbar .navbar-item,
.navbar .navbar-link {
color: #08383b;
font-weight: 700;
}
.navbar .navbar-item.is-active,
.navbar .navbar-item:hover {
background: rgba(255, 255, 255, 0.28) !important;
color: #072d2f !important;
}
.navbar-brand .navbar-item img {
max-height: 2.5rem;
border-radius: 8px;
padding: 4px;
}
.color-picker-app {
width: min(1240px, calc(100% - 20px));
margin: 14px auto 24px;
display: grid;
gap: 16px;
}
.page-hero {
position: relative;
overflow: clip;
display: grid;
grid-template-columns: 1.2fr minmax(140px, 220px);
gap: 12px;
align-items: center;
padding: 16px 18px;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(255, 251, 240, 0.92)),
url('assets/pictures/asfalt-light.png');
border: 1px solid var(--bpb-border);
border-radius: 20px;
box-shadow: var(--bpb-shadow);
}
.page-hero::after {
content: "";
position: absolute;
inset: auto -60px -60px auto;
width: 180px;
height: 180px;
border-radius: 50%;
background: radial-gradient(circle, rgba(14, 167, 160, 0.18), rgba(14, 167, 160, 0));
pointer-events: none;
}
.eyebrow {
margin: 0 0 6px;
color: var(--bpb-accent-strong);
font-size: 0.78rem;
letter-spacing: 0.04em;
}
.page-hero h1 {
margin: 0;
font-size: clamp(1.1rem, 2.8vw, 1.8rem);
line-height: 1.15;
color: #14354a;
}
.page-hero-text {
margin: 8px 0 0;
font-size: 0.88rem;
line-height: 1.35;
color: var(--bpb-muted);
}
.hero-balloons {
position: relative;
min-height: 124px;
display: flex;
align-items: end;
justify-content: center;
}
.hero-balloon {
position: absolute;
width: 52px;
height: 74px;
border-radius: 50% 50% 48% 48% / 44% 44% 56% 56%;
box-shadow: 0 10px 18px rgba(25, 39, 60, 0.16);
animation: heroFloat 5.2s ease-in-out infinite;
}
.hero-balloon::before {
content: "";
position: absolute;
inset: 10px auto auto 10px;
width: 16px;
height: 10px;
border-radius: 50%;
background: rgba(255, 255, 255, 0.55);
transform: rotate(-22deg);
}
.hero-balloon::after {
content: "";
position: absolute;
left: 50%;
top: calc(100% - 2px);
width: 1.5px;
height: 38px;
background: linear-gradient(180deg, rgba(78, 78, 78, 0.9), rgba(78, 78, 78, 0.1));
transform: translateX(-50%);
}
.hero-balloon-a {
background: linear-gradient(160deg, #fff4a5, #ffd25f 52%, #cf9d27);
transform: translate(-34px, 10px) rotate(-4deg);
animation-delay: -0.6s;
}
.hero-balloon-b {
background: linear-gradient(160deg, #d8f9ff, #6fd7eb 52%, #2694b6);
transform: translate(2px, -6px) rotate(5deg);
width: 58px;
height: 82px;
animation-duration: 4.8s;
}
.hero-balloon-c {
background: linear-gradient(160deg, #ffe4ee, #ff9dc1 54%, #cc5d86);
transform: translate(42px, 6px) rotate(7deg);
animation-delay: -1.4s;
animation-duration: 5.6s;
}
@keyframes heroFloat {
0%, 100% { transform: translate(var(--x, 0), var(--y, 0)) rotate(var(--r, 0deg)); }
50% { transform: translate(var(--x, 0), calc(var(--y, 0) - 8px)) rotate(calc(var(--r, 0deg) * -1)); }
}
.hero-balloon-a { --x: -34px; --y: 10px; --r: -4deg; }
.hero-balloon-b { --x: 2px; --y: -6px; --r: 5deg; }
.hero-balloon-c { --x: 42px; --y: 6px; --r: 7deg; }
.picker-layout {
display: grid;
grid-template-columns: minmax(300px, 420px) minmax(0, 1fr);
gap: 16px;
align-items: start;
}
#selected-palette {
position: sticky;
top: 10px;
z-index: 5;
display: grid;
gap: 12px;
padding: 14px;
background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255,252,244,0.92));
border: 1px solid var(--bpb-border-strong);
border-radius: var(--radius-lg);
box-shadow: var(--bpb-shadow);
backdrop-filter: blur(4px);
max-height: calc(100vh - 28px);
}
#selected-palette.stuck {
box-shadow: var(--bpb-shadow-strong);
}
.palette-header-row {
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
gap: 10px;
align-items: start;
}
.palette-title-group h2 {
margin: 0;
font-size: 1.15rem;
color: #15384c;
}
.palette-subtitle {
margin: 4px 0 0;
font-size: 0.72rem;
line-height: 1.3;
color: var(--bpb-muted);
}
#palette-controls {
display: flex;
align-items: center;
gap: 8px;
flex-wrap: wrap;
justify-content: flex-end;
}
.palette-meta-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 8px;
flex-wrap: wrap;
}
.palette-count-badge {
display: inline-flex;
align-items: center;
padding: 4px 10px;
border-radius: 999px;
background: rgba(14, 167, 160, 0.1);
border: 1px solid rgba(14, 167, 160, 0.25);
color: #0b6561;
font-size: 0.76rem;
}
.palette-hint {
font-size: 0.72rem;
color: var(--bpb-muted);
}
#palette-colors {
position: relative;
min-height: 190px;
max-height: min(52vh, 420px);
padding: 10px 10px 16px;
border-radius: var(--radius-md);
border: 1px solid var(--compare-border);
background:
radial-gradient(circle at 18% 14%, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0) 38%),
linear-gradient(180deg, #e1e6ea 0%, #e1e6ea 100%);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
display: flex;
flex-wrap: wrap;
justify-content: center;
align-content: flex-start;
gap: 8px 10px;
overflow: auto;
}
#palette-colors.is-empty {
display: grid;
place-items: center;
}
.palette-empty-state {
display: grid;
gap: 6px;
justify-items: center;
text-align: center;
color: var(--bpb-muted);
padding: 18px 8px;
}
.palette-empty-state i {
font-size: 1.3rem;
color: rgba(21, 56, 76, 0.45);
}
.palette-empty-state strong {
color: #17384c;
font-size: 0.9rem;
}
.palette-empty-state span {
font-size: 0.74rem;
line-height: 1.35;
}
.palette-footer-row {
display: flex;
justify-content: flex-end;
}
#clear-palette {
border: 1px solid rgba(21, 56, 76, 0.18);
background: #ffffff;
color: #15384c;
padding: 8px 12px;
border-radius: 999px;
cursor: pointer;
font-size: 0.82rem;
box-shadow: 0 6px 12px rgba(24, 40, 72, 0.06);
}
#clear-palette:hover {
background: #f8f3e6;
}
#clear-palette:disabled,
.palette-control-btn:disabled {
opacity: 0.45;
cursor: not-allowed;
}
.library-panel {
display: grid;
gap: 12px;
min-width: 0;
}
.library-inline-title {
margin: 0;
padding: 2px 4px 0;
font-size: 0.95rem;
color: #15384c;
}
.library-header {
padding: 14px 16px;
border-radius: var(--radius-lg);
border: 1px solid var(--bpb-border);
background: rgba(255, 253, 246, 0.86);
box-shadow: var(--bpb-shadow);
}
.library-header h2 {
margin: 0;
font-size: 1.05rem;
color: #15384c;
}
.library-header p {
margin: 5px 0 0;
color: var(--bpb-muted);
font-size: 0.78rem;
line-height: 1.35;
}
.library-controls {
margin-top: 10px;
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
gap: 8px;
align-items: center;
}
.library-search {
display: grid;
grid-template-columns: auto minmax(0, 1fr);
align-items: center;
gap: 6px;
border: 1px solid rgba(21, 56, 76, 0.14);
background: rgba(255, 255, 255, 0.88);
border-radius: 999px;
padding: 6px 10px;
}
.library-search i {
color: #6a7880;
font-size: 0.8rem;
}
.library-search input {
border: 0;
outline: 0;
background: transparent;
color: #17384c;
font-family: inherit;
font-size: 0.78rem;
min-width: 0;
}
.library-search input::placeholder {
color: #7c8a92;
}
.library-sort {
display: inline-flex;
align-items: center;
gap: 6px;
color: var(--bpb-muted);
font-size: 0.72rem;
}
.library-sort select {
border: 1px solid rgba(21, 56, 76, 0.14);
border-radius: 999px;
background: rgba(255, 255, 255, 0.92);
color: #17384c;
font-family: inherit;
font-size: 0.72rem;
padding: 6px 10px;
}
.sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
#color-families {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 12px;
width: 100%;
min-width: 0;
}
.color-family {
display: grid;
align-content: start;
gap: 10px;
padding: 14px 12px 16px;
background:
linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,251,240,0.92));
border: 1px solid var(--bpb-border);
border-radius: var(--radius-md);
box-shadow: var(--bpb-shadow);
animation: fadeInUp 0.45s ease;
}
.color-family h3 {
text-align: left;
margin: 0;
padding-inline: 4px;
font-size: 0.95rem;
color: #15384c;
}
.color-family.is-hidden {
display: none;
}
.family-empty-note {
display: none;
}
#color-families.has-filtered-results-none::before {
content: "No colors match that search.";
display: block;
grid-column: 1 / -1;
padding: 16px;
text-align: center;
border-radius: var(--radius-md);
border: 1px dashed rgba(21, 56, 76, 0.2);
background: rgba(255, 255, 255, 0.82);
color: var(--bpb-muted);
box-shadow: var(--bpb-shadow);
}
.swatch-container {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(92px, 1fr));
gap: 10px 8px;
align-items: start;
}
.swatch-wrapper {
position: relative;
display: inline-flex;
flex-direction: column;
align-items: center;
justify-content: flex-start;
gap: 3px;
min-width: 0;
transition: filter 0.2s ease;
filter: drop-shadow(0 3px 4px rgba(0, 0, 0, 0.18));
}
.swatch-wrapper:hover {
filter: drop-shadow(0 6px 10px rgba(0, 0, 0, 0.2));
}
.color-swatch {
width: var(--swatch-w);
height: var(--swatch-h);
position: relative;
z-index: 1;
background: radial-gradient(circle at 30% 30%, #fff5, transparent 60%), #ddd;
transition: transform 0.2s ease;
cursor: pointer;
-webkit-tap-highlight-color: transparent;
-webkit-mask-image: url('images/balloon-mask.svg');
-webkit-mask-size: contain;
-webkit-mask-repeat: no-repeat;
-webkit-mask-position: center;
mask-image: url('images/balloon-mask.svg');
mask-size: contain;
mask-repeat: no-repeat;
mask-position: center;
}
.color-swatch:hover,
.color-swatch:active {
transform: translateY(-2px) scale(1.05);
}
.color-swatch:focus-visible {
outline: 3px solid rgba(14, 167, 160, 0.45);
outline-offset: 3px;
border-radius: 14px;
}
.color-background {
width: 100%;
height: 100%;
border-radius: 50%;
border: 2px solid rgba(0, 0, 0, 0.08);
background-size: cover;
background-position: center;
background-repeat: no-repeat;
}
.color-background.finish-image {
background-size: 125%;
background-position: center;
}
.color-background.chosen {
border-color: rgba(12, 86, 109, 0.55);
box-shadow:
inset 0 0 0 2px rgba(255, 255, 255, 0.28),
0 0 0 3px rgba(14, 167, 160, 0.22);
}
.color-shine {
position: absolute;
top: 45%;
left: 45%;
width: 70px;
opacity: 0.62;
z-index: 100;
pointer-events: none;
transform: translate(-50%, -50%);
height: auto;
}
.color-shine.has-halo {
filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.4));
}
.color-name {
transition: color 0.2s ease, text-decoration-color 0.2s ease;
font-size: 0.76rem;
line-height: 1.15;
text-align: center;
color: #334854;
width: min(100%, 98px);
min-height: 1.7em;
white-space: normal;
word-break: break-word;
}
.color-name.highlighted-name {
text-decoration: underline;
text-decoration-thickness: 2px;
text-underline-offset: 2px;
font-weight: 700;
color: #132f42;
}
#selected-palette .swatch-wrapper {
gap: 4px;
}
#selected-palette .color-swatch {
width: var(--palette-swatch-w);
height: var(--palette-swatch-h);
}
#selected-palette .color-swatch:hover,
#selected-palette .color-swatch:active {
transform: translateY(-2px) scale(1.03);
}
#selected-palette .color-name {
width: min(100%, 84px);
font-size: 0.68rem;
min-height: 2.2em;
}
.balloon-float-group {
position: relative;
display: flex;
flex-direction: column;
align-items: center;
animation-name: balloonFloat;
animation-duration: 4s;
animation-timing-function: ease-in-out;
animation-iteration-count: infinite;
transform-origin: bottom center;
}
@keyframes balloonFloat {
0%, 100% { transform: translateY(0); }
50% { transform: translateY(-14px); }
}
.balloon-string-svg {
position: absolute;
top: var(--string-top);
left: calc(47% - 3px);
transform: translateX(-50%);
width: 18px;
height: 38px;
z-index: -1;
pointer-events: none;
overflow: visible;
transform-origin: top center;
}
#selected-palette .balloon-string-svg {
top: var(--palette-string-top);
height: 32px;
}
.wiggle-path {
stroke: #727171;
stroke-width: 2;
fill: none;
stroke-linecap: round;
}
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(8px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes pop {
0% { transform: scale(1); }
50% { transform: scale(1.12); }
100% { transform: scale(1); }
}
.color-background.pop {
animation: pop 0.25s ease;
}
.chosen {
z-index: 4;
}
/* Shared metallic style */
.metallic {
position: relative;
border: 1px solid rgba(255, 255, 255, 0.3);
overflow: hidden;
}
.chrome-gold {
background: linear-gradient(145deg, #fefcea, #b69978, #a18b67, #806748);
}
.chrome-silver {
background: linear-gradient(145deg, #e0e0e0, #a9a9a9, #808080, #e0e0e0);
}
.chrome-rosegold {
background: linear-gradient(145deg, #fbe3dc, #e6b7a9, #d19387, #fbe3dc);
}
.chrome-champagne {
background: linear-gradient(145deg, #fff2cc, #f2e6b6, #d9c08e, #fff2cc);
}
.chrome-blue {
background: linear-gradient(145deg, #d0f0ff, #4d7995, #2d576f, #d0f0ff);
}
.chrome-purple {
background: linear-gradient(145deg, #e0ccff, #b08be1, #915bc4, #e0ccff);
}
.chrome-green {
background: linear-gradient(145deg, #e2ffe2, #457066, #5c877d, #e2ffe2);
}
#palette-controls .palette-control-btn {
font-size: 0.95rem;
padding: 0;
border: 1px solid var(--bpb-border);
background: #fff;
color: #17384c;
border-radius: 10px;
cursor: pointer;
width: 34px;
height: 34px;
display: inline-flex;
justify-content: center;
align-items: center;
transition: background-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
box-shadow: 0 4px 10px rgba(24, 40, 72, 0.08);
}
#palette-controls .palette-control-btn:hover {
background: #f7f2e2;
transform: translateY(-1px);
}
.switch {
position: relative;
display: inline-block;
width: 40px;
height: 20px;
}
.switch input {
opacity: 0;
width: 0;
height: 0;
}
.slider {
position: absolute;
cursor: pointer;
inset: 0;
background-color: #e6dfc8;
transition: 0.3s;
border-radius: 20px;
border: 1px solid rgba(21, 56, 76, 0.12);
}
.slider:before {
position: absolute;
content: "";
height: 14px;
width: 14px;
left: 2px;
bottom: 2px;
background-color: white;
transition: 0.3s;
border-radius: 50%;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}
input:checked + .slider {
background-color: var(--bpb-accent);
}
input:checked + .slider:before {
transform: translateX(19px);
}
.palette-modal-backdrop {
position: fixed;
inset: 0;
background: rgba(11, 20, 32, 0.55);
display: none;
justify-content: center;
align-items: center;
padding: 16px;
z-index: 1000;
}
.palette-modal-backdrop .palette-modal {
background: var(--bpb-panel-strong);
padding: 18px;
border-radius: 16px;
border: 1px solid var(--bpb-border);
max-width: 480px;
width: min(100%, 480px);
box-shadow: var(--bpb-shadow-strong);
text-align: center;
display: block;
}
.palette-modal h3 {
margin: 0;
color: #15384c;
}
.preset-modal-backdrop {
position: fixed;
inset: 0;
display: none;
justify-content: center;
align-items: center;
padding: 16px;
background: rgba(11, 20, 32, 0.42);
z-index: 1000;
}
.preset-modal {
width: min(100%, 720px);
max-height: min(82vh, 760px);
overflow: auto;
background: rgba(255, 253, 247, 0.96);
border: 1px solid var(--bpb-border);
border-radius: 16px;
box-shadow: var(--bpb-shadow-strong);
padding: 14px;
}
.preset-modal-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 10px;
}
.preset-modal-header h3 {
margin: 0;
color: #15384c;
font-size: 1rem;
}
#close-preset-modal {
width: 28px;
height: 28px;
border-radius: 50%;
border: 1px solid rgba(21, 56, 76, 0.14);
background: #fff;
color: #15384c;
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
}
#close-preset-modal:hover {
background: #f7f2e2;
}
.preset-modal-subtitle {
margin: 6px 0 10px;
color: var(--bpb-muted);
font-size: 0.75rem;
}
#preset-palette-list {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 10px;
}
.preset-card {
display: grid;
gap: 8px;
padding: 10px;
border-radius: 14px;
border: 1px solid rgba(21, 56, 76, 0.1);
background: rgba(255, 255, 255, 0.86);
box-shadow: 0 4px 10px rgba(24, 40, 72, 0.05);
}
.preset-card-title-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 8px;
}
.preset-card-title {
margin: 0;
font-size: 0.82rem;
color: #15384c;
line-height: 1.15;
}
.preset-card-tag {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 2px 8px;
border-radius: 999px;
border: 1px solid rgba(21, 56, 76, 0.1);
background: rgba(21, 56, 76, 0.05);
color: #47616f;
font-size: 0.6rem;
white-space: nowrap;
}
.preset-card-desc {
margin: 0;
color: #5f6f78;
font-size: 0.68rem;
line-height: 1.3;
min-height: 2.2em;
}
.preset-preview {
display: flex;
gap: 6px;
align-items: center;
flex-wrap: wrap;
}
.preset-dot {
width: 18px;
height: 18px;
border-radius: 50%;
border: 1px solid rgba(21, 56, 76, 0.15);
box-shadow: inset 0 1px 0 rgba(255,255,255,0.4);
flex: 0 0 auto;
}
.preset-dot.is-image {
background-size: 220%;
background-position: center 34%;
background-repeat: no-repeat;
}
.preset-card button {
justify-self: start;
border: 1px solid rgba(21, 56, 76, 0.14);
background: #fff;
color: #15384c;
border-radius: 999px;
padding: 6px 10px;
font-size: 0.72rem;
cursor: pointer;
}
.preset-card button:hover {
background: #f7f2e2;
}
#share-link-input {
display: block;
width: 100%;
padding: 10px;
margin: 14px auto 0;
border: 1px solid #d7d7d7;
border-radius: 8px;
font-size: 0.9rem;
text-align: left;
background: #fff;
}
#copy-link-button,
#close-modal {
margin-top: 14px;
padding: 9px 14px;
font-size: 0.9rem;
font-weight: 700;
border-radius: 999px;
border: 1px solid rgba(21, 56, 76, 0.15);
cursor: pointer;
}
#copy-link-button {
background: var(--bpb-accent);
color: white;
border-color: var(--bpb-accent-strong);
}
#copy-link-button:hover {
background: var(--bpb-accent-strong);
}
#close-modal {
margin-left: 8px;
background: #fff;
color: #15384c;
}
#zoom-overlay {
position: fixed;
inset: 0;
background-color: rgba(0, 0, 0, 0.78);
z-index: 1001;
display: flex;
justify-content: center;
align-items: center;
opacity: 0;
visibility: hidden;
transition: opacity 0.25s ease, visibility 0.25s ease;
cursor: zoom-out;
padding: 16px;
}
#zoom-overlay.is-active {
opacity: 1;
visibility: visible;
}
#zoom-modal-shell {
position: relative;
width: min(94vw, 1120px);
}
#zoomed-palette-content {
width: 100%;
max-height: 82vh;
padding: 16px;
background:
linear-gradient(180deg, #eef0f3 0%, #dfe4e9 100%);
border-radius: 16px;
border: 1px solid var(--bpb-border);
box-shadow: var(--bpb-shadow-strong);
overflow: auto;
display: block;
cursor: default;
}
.zoom-palette-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(168px, 1fr));
gap: 12px;
align-items: start;
}
.zoom-color-card {
display: grid;
gap: 4px;
justify-items: center;
align-content: start;
padding: 10px 10px 8px;
background: transparent;
border: 0;
border-radius: 0;
box-shadow: none;
}
.zoom-balloon-wrap {
height: 138px;
display: flex;
align-items: flex-end;
justify-content: center;
width: 100%;
}
.zoom-color-balloon {
width: 120px;
height: 164px;
cursor: default;
filter: drop-shadow(0 10px 14px rgba(24, 40, 72, 0.2));
}
#zoomed-palette-content .zoom-color-balloon .color-background {
border: 2px solid rgba(21, 56, 76, 0.2);
}
#zoomed-palette-content .zoom-color-balloon .color-background.chosen {
border-color: rgba(21, 56, 76, 0.34);
box-shadow:
inset 0 0 0 2px rgba(255, 255, 255, 0.45),
0 0 0 3px rgba(21, 56, 76, 0.12);
}
.zoom-color-balloon:hover,
.zoom-color-balloon:active {
transform: none;
}
.zoom-color-balloon .color-shine {
width: 84px;
}
.zoom-color-name {
text-align: center;
color: #15384c;
font-size: 0.8rem;
line-height: 1.05;
margin-top: -18px;
}
#zoom-close {
position: absolute;
top: -10px;
right: -10px;
display: inline-flex;
align-items: center;
justify-content: center;
width: 32px;
height: 32px;
border-radius: 50%;
background: var(--bpb-panel-strong);
border: 1px solid var(--bpb-border);
color: #15384c;
text-decoration: none;
font-size: 20px;
line-height: 1;
z-index: 1002;
}
#zoom-close:hover {
background: #f7f2e2;
}
footer {
text-align: center;
font-size: 0.8rem;
color: #5f6f78;
padding: 10px 16px 22px;
}
@media (max-width: 1100px) {
.picker-layout {
grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
}
#color-families {
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.swatch-container {
grid-template-columns: repeat(auto-fill, minmax(84px, 1fr));
}
:root {
--swatch-w: 96px;
--swatch-h: 132px;
--palette-swatch-w: 80px;
--palette-swatch-h: 110px;
--string-top: 78px;
--palette-string-top: 64px;
}
.color-shine {
width: 62px;
}
}
@media (min-width: 1101px) {
.picker-layout {
grid-template-columns: minmax(320px, 390px) minmax(0, 1fr);
gap: 18px;
}
#color-families {
grid-template-columns: 1fr;
gap: 10px;
}
.color-family {
grid-template-columns: 180px minmax(0, 1fr);
align-items: start;
gap: 12px;
padding: 12px 14px;
}
.color-family h3 {
margin: 0;
padding: 8px 10px;
border-radius: 12px;
background: rgba(21, 56, 76, 0.05);
border: 1px solid rgba(21, 56, 76, 0.08);
line-height: 1.15;
position: sticky;
top: 0;
}
.swatch-container {
display: flex;
flex-wrap: wrap;
justify-content: flex-start;
align-items: flex-start;
gap: 10px 8px;
}
.swatch-container .swatch-wrapper {
width: 106px;
}
.swatch-container .color-name {
width: 100%;
min-height: 1.9em;
}
}
@media (max-width: 900px) {
.picker-layout {
grid-template-columns: 1fr;
}
#selected-palette {
position: sticky;
top: 6px;
max-height: none;
}
#palette-colors {
min-height: 112px;
max-height: none;
display: flex;
flex-wrap: nowrap;
justify-content: flex-start;
align-items: flex-start;
align-content: stretch;
overflow-x: auto;
overflow-y: hidden;
padding: 8px 10px 10px;
gap: 6px;
scroll-snap-type: x proximity;
}
#selected-palette .swatch-wrapper {
flex: 0 0 auto;
scroll-snap-align: start;
}
#selected-palette .color-name {
display: none;
}
#selected-palette .balloon-float-group {
margin-bottom: 2px;
}
.page-hero {
grid-template-columns: 1fr;
gap: 8px;
padding-right: 14px;
}
.hero-balloons {
min-height: 96px;
justify-content: flex-end;
margin-right: 8px;
}
.library-header {
position: sticky;
top: 6px;
z-index: 4;
backdrop-filter: blur(5px);
}
.library-controls {
grid-template-columns: 1fr;
align-items: stretch;
}
.library-sort {
justify-content: space-between;
}
}
@media (max-width: 640px) {
.color-picker-app {
width: calc(100% - 10px);
margin-top: 8px;
gap: 10px;
}
.page-hero {
padding: 12px;
border-radius: 16px;
}
.page-hero h1 {
font-size: 1.02rem;
}
.page-hero-text {
font-size: 0.76rem;
}
#selected-palette {
padding: 10px;
gap: 10px;
border-radius: 16px;
}
.palette-header-row {
grid-template-columns: 1fr;
}
#palette-controls {
justify-content: space-between;
width: 100%;
}
.palette-meta-row {
align-items: flex-start;
flex-direction: column;
}
.library-search {
padding: 5px 9px;
}
.library-search input,
.library-sort,
.library-sort select {
font-size: 0.68rem;
}
#palette-colors {
min-height: 86px;
gap: 4px;
padding: 6px 8px 8px;
}
#color-families {
grid-template-columns: 1fr;
gap: 10px;
}
.color-family {
padding: 12px 10px 14px;
}
.swatch-container {
grid-template-columns: repeat(auto-fill, minmax(76px, 1fr));
gap: 8px 6px;
}
:root {
--swatch-w: 84px;
--swatch-h: 116px;
--palette-swatch-w: 62px;
--palette-swatch-h: 86px;
--string-top: 68px;
--palette-string-top: 48px;
}
.color-shine {
width: 54px;
}
.color-name {
font-size: 0.68rem;
width: min(100%, 82px);
}
#selected-palette .color-name {
display: none;
}
#selected-palette .balloon-string-svg {
height: 24px;
width: 16px;
}
#zoomed-palette-content {
padding: 14px;
border-radius: 14px;
}
.zoom-palette-grid {
grid-template-columns: repeat(auto-fit, minmax(136px, 1fr));
gap: 10px;
}
.zoom-color-card {
padding: 9px 8px 7px;
gap: 3px;
}
.zoom-balloon-wrap {
height: 112px;
}
.zoom-color-balloon {
width: 100px;
height: 136px;
filter: drop-shadow(0 8px 12px rgba(24, 40, 72, 0.18));
}
.zoom-color-balloon .color-shine {
width: 70px;
}
.zoom-color-name {
font-size: 0.68rem;
margin-top: -14px;
}
#zoom-close {
top: -8px;
right: -8px;
}
.navbar-brand .navbar-item img {
max-height: 2rem;
}
#preset-palette-list {
grid-template-columns: 1fr;
}
}
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
scroll-behavior: auto !important;
}
}