:root{--bg:#fafaf8;--bg-card:#fff;--bg-input:#f0f0ec;--surface:#f5f5f2;--text:#555;--text-h:#1a1a1a;--text-dim:#aaa;--text-secondary:#888;--border:#e4e4e0;--radius:12px;--radius-sm:8px;--shadow:0 2px 12px #0000000f;--shadow-hover:0 8px 30px #0000001a;--font-ui:"Space Grotesk", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;font-family:var(--font-ui);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg)}[data-theme=dark]{--bg:#111;--bg-card:#1a1a1a;--bg-input:#252525;--surface:#222;--text:#aaa;--text-h:#eee;--text-dim:#666;--text-secondary:#888;--border:#333;--shadow:0 2px 12px #0000004d;--shadow-hover:0 8px 30px #0006;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*,:before,:after{box-sizing:border-box}:focus-visible{outline:2px solid var(--accent,#6366f1);outline-offset:2px}button:focus:not(:focus-visible){outline:none}button:active:not(:disabled){transform:scale(.97)}button:disabled{opacity:.5;cursor:not-allowed}.app-main,.home,.about,.explore{animation:.15s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.spinner{border:2.5px solid var(--border);border-top-color:var(--text-h);border-radius:50%;width:24px;height:24px;margin:0 auto 12px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.share-toast{background:var(--text-h);color:var(--bg);font-size:13px;font-family:var(--font-ui);z-index:2000;box-shadow:var(--shadow-hover);border-radius:100px;padding:10px 20px;animation:.3s toastIn;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.image-uploader__loading,.image-uploader__error{text-align:center;color:var(--text-secondary);padding:48px 16px;font-size:14px}.image-uploader__error{color:#dc2626}body{background:var(--bg);min-height:100vh;margin:0;transition:background .3s}.home{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:85vh;padding:40px 20px;display:flex}.home__title{color:var(--text-h);letter-spacing:-.5px;margin:0;font-size:36px;font-weight:700}.home__subtitle{color:var(--text-dim);margin:0;font-size:16px}.home__swatch{cursor:pointer;width:200px;height:200px;box-shadow:0 6px 32px #0000001f, 0 0 0 4px var(--bg-card);border-radius:50%;transition:transform .2s,box-shadow .2s;position:relative}.home__swatch:hover{box-shadow:0 8px 40px #00000029, 0 0 0 4px var(--bg-card);transform:scale(1.04)}.home__color-input{opacity:0;cursor:pointer;border-radius:50%;width:100%;height:100%;position:absolute;inset:0}.home__go{font-size:16px;font-weight:600;font-family:var(--font-ui);background:var(--text-h);color:var(--bg);cursor:pointer;border:none;border-radius:100px;padding:14px 48px;transition:transform .15s,box-shadow .15s}.home__go:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}.home__alt{gap:24px;margin-top:12px;display:flex}.home__link{color:var(--text-dim);font-family:var(--font-ui);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;font-size:13px;text-decoration:underline;transition:color .15s}.home__link:hover{color:var(--text)}.home__bottom{gap:8px;display:flex;position:fixed;top:20px;right:24px}.home__theme{background:var(--bg-card);border:1px solid var(--border);color:var(--text);font-family:var(--font-ui);cursor:pointer;border-radius:100px;padding:6px 14px;font-size:12px}.about{max-width:560px;margin:0 auto;padding:60px 24px}.about__back{color:var(--text);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;margin-bottom:32px;padding:0;font-size:14px}.about__back:hover{color:var(--text-h)}.about__title{color:var(--text-h);margin:0 0 16px;font-size:28px;font-weight:700}.about__subtitle{color:var(--text-h);margin:28px 0 8px;font-size:16px;font-weight:600}.about__text{color:var(--text);margin:0 0 8px;font-size:14px;line-height:1.7}.about__link{color:var(--text-h);border-bottom:1px solid var(--border);text-decoration:none}.about__link:hover{border-color:var(--text-h)}.app-nav__btn.app-nav__home{color:var(--text-dim);justify-content:center;align-items:center;padding:8px 12px;display:flex}.app-nav__home:hover{color:var(--text-h)}#app{max-width:1200px;margin:0 auto;padding:0 24px 60px}.app-header{margin-bottom:12px;padding:28px 0 16px}.app-header__top{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.app-header__title{color:var(--text-h);letter-spacing:-.5px;margin:0 0 2px;font-size:24px;font-weight:700}.app-header__tagline{color:var(--text-dim);font-size:13px;display:block}.app-header__right{align-items:center;gap:8px;display:flex}.theme-toggle{border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-family:var(--font-ui);box-shadow:var(--shadow);padding:8px 16px;font-weight:500;transition:all .2s}.theme-toggle:hover{color:var(--text-h);border-color:var(--text-dim);box-shadow:var(--shadow-hover)}.auth-btn-wrap{display:inline-flex}.auth-sign-in{border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-family:var(--font-ui);box-shadow:var(--shadow);padding:8px 16px;font-weight:500;transition:all .2s}.auth-sign-in:hover{color:var(--text-h);border-color:var(--text-dim)}.auth-avatar{border:1px solid var(--border);background:var(--bg-input);width:34px;height:34px;color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-ui);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.auth-avatar:hover{border-color:var(--text-dim)}.auth-avatar__img{object-fit:cover;width:100%;height:100%}.auth-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.auth-modal{background:var(--bg-card);border-radius:var(--radius);width:100%;max-width:380px;padding:32px;position:relative;box-shadow:0 16px 48px #0003}.auth-modal__title{color:var(--text-h);font-size:20px;font-weight:700;font-family:var(--font-ui);margin:0 0 20px}.auth-modal__google{border:1px solid var(--border);background:var(--bg-card);width:100%;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-family:var(--font-ui);padding:10px;font-weight:500;transition:all .2s}.auth-modal__google:hover{border-color:var(--text-dim);background:var(--bg-input)}.auth-modal__divider{text-align:center;color:var(--text-dim);margin:16px 0;font-size:12px;position:relative}.auth-modal__divider:before,.auth-modal__divider:after{content:"";background:var(--border);width:40%;height:1px;position:absolute;top:50%}.auth-modal__divider:before{left:0}.auth-modal__divider:after{right:0}.auth-modal__form{flex-direction:column;gap:10px;display:flex}.auth-modal__input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:14px;font-family:var(--font-ui);outline:none;padding:10px 12px;transition:border-color .2s}.auth-modal__input:focus{border-color:var(--text-dim)}.auth-modal__submit{background:var(--text-h);color:var(--bg);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-family:var(--font-ui);border:none;padding:10px;font-weight:600;transition:opacity .2s}.auth-modal__submit:hover{opacity:.9}.auth-modal__submit:disabled{opacity:.5;cursor:default}.auth-modal__error{color:#e53e3e;min-height:0;font-size:13px}.auth-modal__error:empty{display:none}.auth-modal__toggle{color:var(--text-dim);font-size:13px;font-family:var(--font-ui);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;align-self:center;padding:0;text-decoration:underline}.auth-modal__toggle:hover{color:var(--text)}.auth-modal__close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:24px;line-height:1;position:absolute;top:12px;right:16px}.auth-modal__close:hover{color:var(--text)}.app-nav{background:var(--bg-input);border-radius:var(--radius);gap:6px;padding:4px;display:flex}.app-nav__btn{color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-family:var(--font-ui);background:0 0;border:none;padding:10px 24px;font-weight:600;transition:all .2s}.app-nav__btn:hover{color:var(--text-h)}.app-nav__btn--active{background:var(--bg-card);color:var(--text-h);box-shadow:var(--shadow)}.app-main{min-height:60vh}.picker-section{max-width:1100px;margin-bottom:8px;margin-left:auto;margin-right:auto}.picker-section__toggle{border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-family:var(--font-ui);box-shadow:var(--shadow);align-items:center;gap:6px;padding:6px 14px;font-weight:600;transition:all .15s;display:inline-flex}.picker-section__toggle svg{opacity:.7}.picker-section__toggle:hover,.picker-section--expanded .picker-section__toggle{color:var(--text-h);border-color:var(--text-dim)}.picker-section__body{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-width:440px;box-shadow:var(--shadow);margin-top:8px;margin-bottom:8px;padding:14px;display:none}.picker-section--expanded .picker-section__body{display:block}.catalog-layout{flex-direction:column;gap:48px;display:flex}.catalog-layout__title{color:var(--text-h);margin:0 0 16px;font-size:18px;font-weight:700}.color-picker{align-items:stretch;gap:16px;display:flex}.color-picker__left{flex-direction:column;flex-shrink:0;gap:8px;width:100px;display:flex}.color-picker__preview{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);width:100%;transition:box-shadow .2s;position:relative;overflow:hidden}.color-picker__preview:hover{box-shadow:var(--shadow-hover)}.color-picker__native{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.color-picker__hex-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-h);font-family:var(--font-mono);letter-spacing:.5px;text-align:center;box-sizing:border-box;padding:6px 8px;font-size:12px;font-weight:600;transition:border-color .2s}.color-picker__hex-input:focus{border-color:var(--text-dim);outline:none}.color-picker__right{flex-direction:column;flex:1;justify-content:center;gap:8px;min-width:0;display:flex}.color-picker__slider-group{flex-direction:column;gap:4px;display:flex}.color-picker__slider-label{justify-content:space-between;align-items:center;display:flex}.color-picker__slider-label label{color:var(--text-dim);font-size:11px;font-weight:600}.color-picker__slider-label span{color:var(--text);font-size:11px;font-family:var(--font-mono)}.color-picker__slider{appearance:none;background:var(--track-gradient,var(--bg-input));border-radius:3px;outline:none;width:100%;height:6px}.color-picker__slider::-webkit-slider-thumb{appearance:none;border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:50%;width:16px;height:16px;transition:box-shadow .15s;box-shadow:0 1px 4px #00000026}.color-picker__slider::-webkit-slider-thumb:hover{box-shadow:0 2px 8px #00000040}.color-picker__slider::-moz-range-thumb{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:50%;width:16px;height:16px;box-shadow:0 1px 4px #00000026}@media (width<=600px){.color-picker__left{width:80px}.color-picker__slider{border-radius:5px;height:10px}.color-picker__slider::-webkit-slider-thumb{width:28px;height:28px}.color-picker__slider::-moz-range-thumb{width:28px;height:28px}}.compat{max-width:1100px;margin:40px auto 0;padding:0 16px}.compat__title{color:var(--text-h);margin:0 0 6px;font-size:16px;font-weight:700}.compat__desc{color:var(--text-secondary);margin:0 0 16px;font-size:13px;line-height:1.5}.compat__legend{color:var(--text-secondary);gap:16px;margin-bottom:12px;font-size:12px;display:flex}.compat__legend-item{align-items:center;gap:5px;display:flex}.compat__dot{border-radius:50%;width:10px;height:10px}.compat__dot--same{background:#22c55e}.compat__dot--ok{background:#60a5fa}.compat__dot--caution{background:#f59e0b}.compat__grid{border-radius:var(--radius);border:1px solid var(--border);gap:2px;display:grid;overflow:hidden}.compat__cell{text-align:center;background:var(--bg-card);justify-content:center;align-items:center;min-height:38px;padding:8px 4px;font-size:11px;font-weight:500;display:flex}.compat__cell--header{background:var(--surface);color:var(--text-h);text-transform:uppercase;letter-spacing:.03em;font-size:10px;font-weight:700}.compat__cell--row{text-align:right;justify-content:flex-end;padding-right:8px}.compat__cell--same{color:#22c55e;font-weight:700}.compat__cell--ok{color:#60a5fa}.compat__cell--caution{color:#f59e0b;background:#f59e0b14;font-weight:700}.compat__footnote{color:var(--text-dim);margin:12px 0 0;font-size:12px;font-style:italic}.pb-compat-warn{border-radius:var(--radius-sm);color:#b45309;background:#f59e0b14;border:1px solid #f59e0b33;align-items:center;gap:8px;margin-top:8px;padding:8px 14px;font-size:12px;line-height:1.4;display:flex}.pb-compat-warn svg{color:#f59e0b;flex-shrink:0}[data-theme=dark] .pb-compat-warn{color:#fbbf24}@media (width<=600px){.compat__cell{min-height:32px;padding:6px 2px;font-size:10px}.compat__cell--header{font-size:9px}.compat__legend{flex-wrap:wrap;gap:8px}}.image-uploader{max-width:1100px;margin:0 auto}.image-uploader__drop-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--bg-card);padding:56px 24px;transition:all .25s}.image-uploader__drop-zone--active,.image-uploader__drop-zone:hover{border-color:var(--text-dim);background:var(--bg-input);box-shadow:var(--shadow)}.image-uploader__icon{opacity:.6;margin-bottom:12px;font-size:40px}.image-uploader__or{color:var(--text-dim);margin:10px 0;font-size:12px}.image-uploader__hint-text{color:var(--text-dim);margin-top:16px;font-size:13px}.image-uploader__btn{background:var(--text-h);color:var(--bg);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-family:var(--font-ui);padding:10px 24px;font-weight:600;transition:opacity .2s,box-shadow .2s;display:inline-block}.image-uploader__btn:hover{opacity:.9;box-shadow:var(--shadow-hover)}.image-uploader__btn input{display:none}.image-uploader__preview{margin-top:24px}.image-uploader__preview-wrap{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.image-uploader__image{border-radius:var(--radius);border:1px solid var(--border);max-width:100%;max-height:300px;box-shadow:var(--shadow)}.image-uploader__new-btn{color:var(--text-dim);font-family:var(--font-ui);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;font-size:13px;text-decoration:underline;transition:color .15s}.image-uploader__new-btn:hover{color:var(--text)}.image-uploader__palette-title{color:var(--text-h);margin:0 0 4px;font-size:16px;font-weight:700}.image-uploader__hint{color:var(--text-dim);margin:0 0 16px;font-size:13px}.image-uploader__color-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;display:grid}.image-uploader__color-card{border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;gap:4px;padding:16px 14px;transition:transform .15s,box-shadow .15s;display:flex}.image-uploader__color-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.image-uploader__card-code{font-size:12px;font-weight:700;font-family:var(--font-mono)}.image-uploader__card-name{font-size:12px;font-weight:600}.image-uploader__card-add{font-size:11px;font-weight:600;font-family:var(--font-ui);cursor:pointer;background:#ffffff26;border:1px solid #fff3;border-radius:100px;align-self:flex-start;margin-top:6px;padding:3px 10px;transition:background .2s}.image-uploader__card-add:hover{background:#ffffff40}.image-uploader__card-add--added{opacity:.5;cursor:default}.image-uploader__actions{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.catalog-browser{max-width:1000px}.catalog-browser__search{margin-bottom:14px}.catalog-browser__input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;max-width:400px;color:var(--text-h);font-size:14px;font-family:var(--font-ui);box-shadow:var(--shadow);padding:12px 16px;transition:border-color .2s,box-shadow .2s}.catalog-browser__input:focus{border-color:var(--text-dim);box-shadow:var(--shadow-hover);outline:none}.catalog-browser__input::placeholder{color:var(--text-dim)}.catalog-browser__filters{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.catalog-browser__filter-btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-family:var(--font-ui);padding:8px 16px;font-weight:600;transition:all .2s}.catalog-browser__filter-btn--active{background:var(--text-h);color:var(--bg);border-color:var(--text-h)}.catalog-browser__sort-btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-family:var(--font-ui);margin-left:auto;padding:8px 14px;font-weight:600;transition:all .2s}.catalog-browser__sort-btn:hover{color:var(--text-h);border-color:var(--text-dim)}.catalog-browser__grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;display:grid}.catalog-browser__swatch{aspect-ratio:1;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-family:var(--font-ui);flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:10px;transition:transform .2s,box-shadow .2s;display:flex;position:relative}.catalog-browser__swatch:hover{box-shadow:var(--shadow-hover);z-index:1;transform:scale(1.06)}.catalog-browser__swatch--in-list{box-shadow:inset 0 0 0 2px}.catalog-browser__swatch-add{cursor:pointer;opacity:0;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;font-weight:700;transition:opacity .2s,background .2s;display:flex;position:absolute;top:4px;right:4px}.catalog-browser__swatch:hover .catalog-browser__swatch-add{opacity:1}.catalog-browser__swatch-add:hover{background:#fff6}.catalog-browser__swatch-add--added{cursor:default;opacity:.6!important}.catalog-browser__swatch-code{font-size:10px;font-weight:700;font-family:var(--font-mono);opacity:.85}.catalog-browser__swatch-name{opacity:.65;text-align:center;font-size:10px}.catalog-browser__empty{color:var(--text-dim);text-align:center;grid-column:1/-1;padding:48px}.saved-palettes{max-width:1100px;margin:0 auto}.saved-palettes__section-title{max-width:1100px;color:var(--text-h);margin:32px auto 12px;font-size:15px;font-weight:700}.saved-palettes__empty{color:var(--text-dim);text-align:center;padding:48px 20px;font-size:14px}.saved-palettes__card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;padding:18px;transition:box-shadow .2s}.saved-palettes__card:hover{box-shadow:var(--shadow-hover)}.saved-palettes__header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.saved-palettes__name{color:var(--text-h);font-size:14px;font-weight:700}.saved-palettes__actions{align-items:center;gap:6px;display:flex}.saved-palettes__load{border:1px solid var(--border);color:var(--text);cursor:pointer;font-size:12px;font-family:var(--font-ui);border-radius:var(--radius-sm);background:0 0;padding:4px 12px;font-weight:600;transition:all .2s}.saved-palettes__load:hover{color:var(--text-h);border-color:var(--text-dim)}.saved-palettes__delete{color:var(--text-dim);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:16px;transition:all .2s}.saved-palettes__delete:hover{color:#dc2626;background:#dc26261a}.saved-palettes__swatches{flex-wrap:wrap;gap:6px;display:flex}.saved-palettes__swatch{border-radius:var(--radius-sm);border:1px solid var(--border);font-size:11px;font-family:var(--font-mono);cursor:pointer;padding:10px 14px;font-weight:600;transition:transform .2s,box-shadow .2s}.saved-palettes__swatch:hover{box-shadow:var(--shadow-hover);transform:scale(1.06)}.saved-palettes__public{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:500;transition:all .15s}.saved-palettes__public--active{color:#16a34a;background:#22c55e1a;border-color:#22c55e4d}.saved-palettes__public:hover{border-color:var(--text-secondary)}.explore{max-width:1100px;margin:0 auto;padding:0 16px}.explore__header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.explore__title{color:var(--text);margin:0;font-size:20px;font-weight:600}.explore__sort{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);gap:4px;padding:3px;display:flex}.explore__sort-btn{border-radius:calc(var(--radius) - 2px);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s}.explore__sort-btn--active{background:var(--bg);color:var(--text);box-shadow:var(--shadow)}.explore__sort-btn:hover:not(.explore__sort-btn--active){color:var(--text)}.explore__loading,.explore__empty{text-align:center;color:var(--text-secondary);padding:48px 16px;font-size:14px}.explore__grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.explore__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:box-shadow .2s,transform .2s;overflow:hidden}.explore__card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}.explore__swatches{height:100px;display:flex}.explore__swatch{flex:1;justify-content:center;align-items:flex-end;min-width:0;padding:8px 4px;display:flex}.explore__swatch-label{font-size:9px;font-family:var(--font-mono);opacity:0;white-space:nowrap;text-overflow:ellipsis;font-weight:600;transition:opacity .15s;overflow:hidden}.explore__card:hover .explore__swatch-label{opacity:.7}.explore__footer{justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;display:flex}.explore__info{flex:1;min-width:0}.explore__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.explore__author{color:var(--text-secondary);margin-top:2px;font-size:11px}.explore__like{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;flex-shrink:0;align-items:center;gap:5px;padding:6px 10px;font-size:12px;transition:all .15s;display:flex}.explore__like:hover{color:#ef4444;border-color:#ef4444}.explore__like--active{color:#ef4444;background:#ef44440d;border-color:#ef44444d}.explore__more{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;margin:24px auto;padding:10px 32px;font-size:14px;font-weight:500;transition:all .15s;display:block}.explore__more:hover{background:var(--bg);box-shadow:var(--shadow)}@media (width<=640px){.explore__grid{grid-template-columns:1fr}.explore__swatches{height:80px}}.palette-builder{max-width:1100px;margin:0 auto}.pb-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.pb-brands{flex-wrap:wrap;gap:5px;margin-bottom:18px;display:flex}.pb-brand{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:12px;font-family:var(--font-ui);background:0 0;border-radius:100px;padding:5px 11px;font-weight:600;transition:all .15s}.pb-brand:hover:not(.pb-brand--active){border-color:var(--text-dim);color:var(--text)}.pb-brand--active{background:var(--text-h);color:var(--bg);border-color:var(--text-h)}.pb-toolbar__left{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pb-toolbar__right{align-items:center;gap:6px;display:flex}.pb-pills{background:var(--bg-input);border-radius:var(--radius-sm);gap:2px;padding:3px;display:flex}.pb-pills--sm .pb-pill{text-align:center;min-width:34px;padding:6px 14px}.pb-pill{color:var(--text-dim);cursor:pointer;font-size:13px;font-family:var(--font-ui);background:0 0;border:none;border-radius:6px;padding:6px 14px;font-weight:600;transition:all .15s}.pb-pill:hover{color:var(--text-h)}.pb-pill--active{background:var(--bg-card);color:var(--text-h);box-shadow:var(--shadow)}.pb-toggle{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:12px;font-family:var(--font-ui);background:0 0;border-radius:6px;padding:5px 12px;font-weight:600;transition:all .15s}.pb-toggle--active{background:var(--bg-card);color:var(--text-h);border-color:var(--text-dim)}.pb-toggle:hover{color:var(--text-h)}.pb-icon-btn{border:1px solid var(--border);background:var(--bg-card);width:36px;height:36px;color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;justify-content:center;align-items:center;transition:all .15s;display:flex}.pb-icon-btn:hover{color:var(--text-h);border-color:var(--text-dim)}.pb-icon-btn--active{color:var(--text-h);border-color:var(--text-dim);background:var(--bg-input)}.pb-brightness{align-items:center;gap:1px;display:flex}.pb-brightness__btn{border:1px solid var(--border);background:var(--bg-card);width:28px;height:28px;color:var(--text-dim);cursor:pointer;font-size:16px;font-weight:700;font-family:var(--font-ui);justify-content:center;align-items:center;transition:all .15s;display:flex}.pb-brightness__btn:first-child{border-radius:6px 0 0 6px}.pb-brightness__btn:last-child{border-left:none;border-radius:0 6px 6px 0}.pb-brightness__btn:hover{color:var(--text-h);border-color:var(--text-dim)}.pb-strip{border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;min-height:260px;box-shadow:0 2px 12px #0000000f, 0 0 0 1px var(--border);display:flex;overflow:hidden}.pb-strip__cell{cursor:pointer;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:5px;padding:20px 10px;transition:flex .3s;display:flex;position:relative}.pb-strip__cell:hover{flex:1.5}.pb-strip__hint{text-transform:uppercase;letter-spacing:1px;opacity:.35;margin-bottom:2px;font-size:9px;font-weight:600}.pb-strip__line{text-transform:uppercase;letter-spacing:.08em;opacity:.5;margin-bottom:2px;font-size:9px;font-weight:700}.pb-strip__code{font-size:12px;font-weight:700;font-family:var(--font-mono)}.pb-strip__name{text-align:center;font-size:11px;font-weight:600;line-height:1.3}.pb-strip__hex{font-size:11px;font-weight:600;font-family:var(--font-mono);opacity:.6}.pb-strip__add{font-size:11px;font-weight:600;font-family:var(--font-ui);cursor:pointer;opacity:0;background:#ffffff26;border:1px solid #fff3;border-radius:100px;margin-top:4px;padding:4px 12px;transition:opacity .2s,background .2s}.pb-strip__cell:hover .pb-strip__add{opacity:1}.pb-strip__add:hover{background:#ffffff40}.pb-strip__add--added{cursor:default;opacity:.5!important}.pb-strip__bright{opacity:0;gap:2px;transition:opacity .2s;display:flex;position:absolute;top:8px;left:8px}.pb-strip__cell:hover .pb-strip__bright{opacity:.6}.pb-strip__bright-btn{width:22px;height:22px;color:inherit;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-ui);background:#80808026;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .15s;display:flex}.pb-strip__bright-btn:hover{background:#8080804d;opacity:1!important}.pb-strip__lock{cursor:pointer;opacity:0;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:opacity .2s;display:flex;position:absolute;top:8px;right:8px}.pb-strip__cell:hover .pb-strip__lock{opacity:.5}.pb-strip__lock:hover{background:#80808026;opacity:.8!important}.pb-strip__lock--active{opacity:.9!important}@media (width<=600px){.pb-strip{flex-direction:column;min-height:auto}.pb-strip__cell{flex-direction:row;justify-content:flex-start;gap:10px;min-height:56px;padding:14px 16px}.pb-strip__cell:hover{flex:1}.pb-strip__cell--selected{background-image:linear-gradient(90deg,#ffffff14 0%,#0000 100%);flex:1}.pb-strip__cell--selected:after{display:none}.pb-strip__add{opacity:1;margin-top:0;margin-left:auto}.pb-strip__lock{opacity:.5;position:static}.pb-strip__hint{display:none}.pb-strip__bright{opacity:.5;margin-left:auto;position:static}}.pb-strip__cell--dragging{opacity:.4}.pb-strip__cell--dragover{box-shadow:inset 0 0 0 3px #ffffff80}.pb-strip__cell--selected{flex:1.5}.pb-strip__cell--selected:after{content:"";border-left:8px solid #0000;border-right:8px solid #0000;border-bottom:8px solid var(--bg);width:0;height:0;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.pb-gradient{border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;min-height:260px;box-shadow:0 2px 12px #0000000f, 0 0 0 1px var(--border);position:relative;overflow:hidden}.pb-gradient__canvas{width:100%;height:260px;display:block}.pb-gradient__labels{pointer-events:none;position:absolute;inset:0}.pb-gradient__label{cursor:pointer;pointer-events:auto;flex-direction:column;justify-content:center;align-items:center;gap:6px;height:100%;display:flex;position:absolute;top:0;transform:translate(-50%)}.pb-gradient__dot{border:2px solid;border-radius:50%;flex-shrink:0;width:14px;height:14px;box-shadow:0 1px 4px #0000004d}.pb-gradient__dot--draggable{cursor:grab;transition:transform .1s,box-shadow .1s}.pb-gradient__dot--draggable:hover{transform:scale(1.3);box-shadow:0 0 0 3px #fff6,0 2px 8px #0000004d}.pb-gradient__dot--active{cursor:grabbing;transform:scale(1.5);box-shadow:0 0 0 3px #ffffff80,0 2px 10px #0006}.pb-gradient__info{text-align:center;background:#00000040;border-radius:6px;padding:4px 8px}.pb-gradient__brand{text-transform:uppercase;letter-spacing:.5px;opacity:.6;white-space:nowrap;font-size:9px;font-weight:600}.pb-gradient__code{font-size:11px;font-weight:700;font-family:var(--font-mono);white-space:nowrap}.pb-gradient__name{opacity:.85;white-space:nowrap;font-size:10px;font-weight:600}.pb-gradient__label--selected .pb-gradient__dot{width:18px;height:18px;box-shadow:0 0 0 3px #ffffff80,0 1px 6px #0006}.pb-similar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:12px;padding:14px}.pb-similar__header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.pb-similar__title{color:var(--text-dim);font-size:12px;font-weight:600}.pb-similar__pick{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font-ui);color:var(--text);align-items:center;gap:6px;padding:5px 12px;transition:all .15s;display:inline-flex}.pb-similar__pick:hover{border-color:var(--text-dim);color:var(--text-h)}.pb-similar__pick-input{border:1px solid var(--border);cursor:pointer;appearance:none;border-radius:4px;width:20px;height:20px;padding:0;overflow:hidden}.pb-similar__pick-input::-webkit-color-swatch-wrapper{padding:0}.pb-similar__pick-input::-webkit-color-swatch{border:none;border-radius:3px}.pb-similar__grid{flex-wrap:wrap;gap:8px;display:flex}.pb-similar__card{border-radius:var(--radius);cursor:pointer;text-align:center;min-width:100px;max-width:160px;font-family:var(--font-ui);border:2px solid #0000;flex-direction:column;flex:1;align-items:center;gap:3px;padding:14px 12px;transition:border-color .2s,transform .15s;display:flex}.pb-similar__card:hover{border-color:#80808066;transform:translateY(-2px)}.pb-similar__line{text-transform:uppercase;letter-spacing:.08em;opacity:.5;margin-bottom:1px;font-size:8px;font-weight:700}.pb-similar__code{font-size:11px;font-weight:700;font-family:var(--font-mono)}.pb-similar__name{font-size:10px;font-weight:600;line-height:1.3}.pb-similar__hex{font-size:10px;font-family:var(--font-mono);opacity:.6}@media (width<=600px){.pb-similar__grid{gap:6px}.pb-similar__card{min-width:80px;padding:10px 8px}}.pb-bottom{background:var(--bg-card);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);border-top:none;align-items:center;gap:12px;padding:10px 14px;display:flex}.pb-primary-btn{background:var(--text-h);color:var(--bg);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-family:var(--font-ui);border:none;padding:9px 20px;font-weight:700;transition:opacity .15s}.pb-primary-btn:hover{opacity:.85}.pb-secondary{align-items:center;gap:4px;display:flex}.pb-link-btn{color:var(--text-dim);cursor:pointer;border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-ui);background:0 0;border:none;padding:6px 12px;font-weight:600;transition:color .15s}.pb-link-btn:hover{color:var(--text-h);background:var(--surface)}.shop-list{max-width:1100px;margin-top:20px;margin-left:auto;margin-right:auto}.shop-list__header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.shop-list__title{color:var(--text-h);margin:0;font-size:16px;font-weight:700}.shop-list__count{color:var(--text-dim);font-size:12px;font-weight:600;font-family:var(--font-mono);margin-left:8px}.shop-list__actions{gap:8px;display:flex}.shop-list__btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-family:var(--font-ui);padding:6px 14px;font-weight:600;transition:all .2s}.shop-list__btn:hover{color:var(--text-h);border-color:var(--text-dim)}.shop-list__btn--clear{color:var(--text-dim)}.shop-list__btn--clear:hover{color:#dc2626;border-color:#dc2626}.shop-list__empty{color:var(--text-dim);padding:16px 0;font-size:13px}.shop-list__items{flex-direction:column;gap:4px;display:flex}.shop-list__item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:8px 12px;transition:box-shadow .2s;display:flex}.shop-list__item:hover{box-shadow:var(--shadow)}.shop-list__swatch{border-radius:6px;flex-shrink:0;width:32px;height:32px}.shop-list__info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.shop-list__code{font-size:12px;font-weight:700;font-family:var(--font-mono);color:var(--text-h)}.shop-list__name{color:var(--text);font-size:12px}.shop-list__remove{color:var(--text-dim);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:14px;transition:all .2s}.shop-list__remove:hover{color:#dc2626;background:#dc26261a}.shop-list__qty{flex-shrink:0;align-items:center;gap:2px;display:flex}.shop-list__qty-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:14px;font-weight:600;transition:all .15s;display:flex}.shop-list__qty-btn:hover:not(:disabled){background:var(--border);color:var(--text-h)}.shop-list__qty-btn:disabled{opacity:.3;cursor:default}.shop-list__qty-label{font-size:12px;font-weight:700;font-family:var(--font-mono);color:var(--text-h);text-align:center;min-width:20px}.catalog-layout__subtitle{color:var(--text-h);margin:24px 0 12px;font-size:15px;font-weight:700}@media (width<=600px){#app{padding:0 12px 40px}.app-header{margin-bottom:20px;padding:16px 0 12px}.app-header__top{margin-bottom:12px}.app-header__title{font-size:18px}.app-header__right{gap:6px}.app-header__right .theme-toggle,.app-header__right .auth-sign-in{padding:5px 10px;font-size:11px}.app-nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;padding:3px;overflow-x:auto}.app-nav::-webkit-scrollbar{display:none}.app-nav__btn{white-space:nowrap;flex-shrink:0;padding:8px 12px;font-size:12px}.app-nav__btn.app-nav__home{padding:8px 10px}.home{gap:20px;min-height:80vh;padding:48px 16px 32px}.home__bottom{gap:6px;top:12px;right:12px}.home__title{font-size:28px}.home__swatch{width:160px;height:160px}.home__go{padding:12px 40px;font-size:15px}.home__alt{flex-direction:column;gap:12px}.palette-builder{max-width:100%}.pb-toolbar{gap:6px;margin-bottom:6px}.pb-pills{gap:1px;padding:2px}.pb-pill{padding:5px 10px;font-size:12px}.pb-icon-btn{width:30px;height:30px}.pb-brightness__btn{width:24px;height:24px;font-size:14px}.pb-strip__bright{opacity:.5}.pb-similar{margin-top:8px;padding:10px}.pb-similar__grid{gap:6px}.pb-similar__card{flex:calc(33% - 4px);min-width:0;max-width:none;padding:10px 6px}.pb-similar__code{font-size:10px}.pb-similar__name{font-size:9px}.pb-bottom{flex-direction:column;align-items:stretch;gap:8px}.pb-primary-btn{width:100%;padding:10px 16px;font-size:13px}.pb-secondary{justify-content:center}.catalog-browser{max-width:100%}.catalog-browser__input{max-width:100%;padding:10px 12px;font-size:14px}.catalog-browser__filters{gap:6px;margin-bottom:12px}.catalog-browser__filter-btn{padding:6px 12px;font-size:12px}.catalog-browser__sort-btn{padding:6px 10px;font-size:11px}.catalog-browser__grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:4px}.catalog-browser__swatch{border-radius:var(--radius-sm);padding:6px}.catalog-browser__swatch-code,.catalog-browser__swatch-name{font-size:8px}.image-uploader__drop-zone{padding:36px 16px}.image-uploader__color-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px}.image-uploader__color-card{padding:12px 10px}.image-uploader__card-code,.image-uploader__card-name{font-size:11px}.image-uploader__actions{gap:6px}.shop-list__header{flex-direction:column;align-items:flex-start;gap:8px}.shop-list__item{gap:8px;padding:8px 10px}.shop-list__swatch{width:28px;height:28px}.shop-list__code,.shop-list__name{font-size:11px}.saved-palettes__card{padding:14px}.saved-palettes__swatches{gap:4px}.saved-palettes__swatch{padding:8px 10px;font-size:10px}.picker-section__toggle{padding:8px 16px;font-size:13px}.picker-section__body{max-width:100%}}
