*{margin:0;padding:0;box-sizing:border-box}:root{--primary: oklch(.3 0 0);--primary-dark: oklch(.2 0 0);--bg: oklch(.98 0 0);--surface: oklch(1 0 0);--text: oklch(.2 0 0);--text-secondary: oklch(.5 0 0);--border: oklch(.9 0 0);--shadow: 0 2px 8px oklch(0 0 0 / .08);--accent: oklch(.15 0 0)}body{font-family:"IBM Plex Serif",Georgia,Times New Roman,serif;background:var(--bg);color:var(--text);line-height:1.6;margin:0;padding:0;height:100vh;overflow:hidden}.app-container{display:grid;grid-template-columns:280px 1fr 320px;height:100vh;gap:0}.thumbnail-sidebar{background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}.sidebar-upload-zone{background:var(--bg);border:2px dashed var(--border);border-radius:12px;padding:24px 16px;margin:12px;text-align:center;cursor:pointer;transition:all .3s ease;flex-shrink:0}.sidebar-upload-zone:hover,.sidebar-upload-zone.drag-over{border-color:var(--text);background:#eee;transform:scale(1.02);box-shadow:0 4px 12px #0000001a}.sidebar-upload-zone svg{color:var(--text);margin-bottom:8px}.upload-text-small{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:4px}.upload-subtext-small{font-size:.75rem;color:var(--text-secondary)}.thumbnails-list{flex:1;overflow-y:auto;padding:0 12px 12px}.empty-state-small{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:.9rem}.thumbnail-item{background:var(--bg);border-radius:12px;padding:12px;margin-bottom:12px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.thumbnail-item:hover{transform:translate(4px);border-color:var(--accent)}.thumbnail-item.active{border-color:var(--accent);background:#f2f2f2;box-shadow:0 4px 12px #00000026}.thumbnail-image{width:100%;height:150px;object-fit:cover;border-radius:8px;margin-bottom:8px}.thumbnail-info{font-size:.85rem}.thumbnail-name{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.thumbnail-size{color:var(--text-secondary);font-size:.75rem}.palettes-main{overflow-y:auto;background:var(--bg)}.main-header{position:sticky;top:0;background:var(--surface);padding:24px;border-bottom:1px solid var(--border);z-index:10;box-shadow:0 2px 8px #0000000d}.main-header h1{font-size:2rem;margin:0 0 4px;color:var(--text);font-weight:700}.main-header p{margin:0 0 16px;color:var(--text-secondary)}.upload-section-inline{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.colors-input{display:flex;align-items:center;gap:8px;font-weight:500}.colors-input input{width:70px;padding:8px 12px;border:2px solid var(--border);border-radius:8px;font-size:1rem}.secondary-btn-small{padding:8px 16px;background:var(--border);border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.secondary-btn-small:hover{background:#cbced4}.palettes-container{padding:24px}.palettes-header{margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--border)}.palettes-header h2{margin:0 0 8px;font-size:1.5rem}.palettes-header p{color:var(--text-secondary);margin:0 0 12px}.header-actions{display:flex;gap:8px}.micro-palette-sidebar{background:var(--surface);border-left:1px solid var(--border);overflow-y:auto;padding:16px}.micro-header{margin-bottom:16px}.micro-header h3{margin:0 0 12px;font-size:1.1rem}.selected-color-info{background:var(--bg);padding:12px;border-radius:8px;font-size:.8rem;min-height:80px}.info-label{color:var(--text-secondary);text-align:center;padding:24px 0}.color-info-swatch{width:100%;height:40px;border-radius:6px;margin-bottom:8px;box-shadow:var(--shadow)}.color-info-details{font-family:SF Mono,Monaco,Consolas,monospace;font-size:.75rem;line-height:1.6}.color-info-details strong{color:var(--text-secondary);font-weight:600}.micro-grid{display:grid;grid-template-columns:repeat(16,1fr);gap:2px;background:var(--border);padding:2px;border-radius:8px}.micro-swatch{aspect-ratio:1;cursor:pointer;transition:all .15s ease}.micro-swatch:hover{transform:scale(1.5);z-index:10;box-shadow:0 2px 8px #0000004d;border:2px solid white}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary);text-align:center}.empty-state svg{color:var(--border);margin-bottom:16px}.empty-state h3{margin:0 0 8px;color:var(--text)}.empty-state p{margin:0}.palette-section{margin-bottom:32px;background:var(--surface);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}.palette-title{font-size:1rem;font-weight:600;padding:16px 20px;color:var(--text);margin:0;background:var(--bg);border-bottom:1px solid var(--border)}.palette{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;padding:20px}.color-card{background:var(--bg);border-radius:12px;padding:12px;transition:transform .2s ease}.color-card:hover{transform:translateY(-4px)}.color-swatch{width:100%;height:80px;border-radius:8px;margin-bottom:12px;box-shadow:var(--shadow);cursor:pointer;position:relative;overflow:hidden}.color-swatch:after{content:"Click to copy";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000b3;color:#fff;font-size:.85rem;font-weight:600;opacity:0;transition:opacity .2s ease}.color-swatch:hover:after{opacity:1}.color-values{font-size:.8rem}.color-value{display:flex;justify-content:space-between;padding:6px 0;font-family:SF Mono,Monaco,Consolas,monospace;gap:8px}.color-value-oklch{padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:4px}.color-value-oklch .value{font-weight:600;letter-spacing:.5px}.color-value .label{color:var(--text-secondary);font-weight:600;min-width:50px;flex-shrink:0}.color-value .value{color:var(--text);word-break:break-word;text-align:right;flex:1}button{padding:10px 20px;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.icon-btn{padding:8px 16px;background:var(--border);color:var(--text);display:inline-flex;align-items:center;gap:6px;font-size:.85rem}.icon-btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}.toast{position:fixed;bottom:20px;right:20px;background:var(--text);color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #0003;animation:toastIn .3s ease;z-index:1000}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{to{opacity:0;transform:translateY(20px)}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1200px){.app-container{grid-template-columns:240px 1fr 280px}.micro-grid{grid-template-columns:repeat(12,1fr)}}@media (max-width: 768px){.app-container{grid-template-columns:1fr;grid-template-rows:auto 1fr}.thumbnail-sidebar{display:flex;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--border)}.thumbnail-item{min-width:200px;margin-right:12px;margin-bottom:0}.micro-palette-sidebar{display:none}.palette{grid-template-columns:1fr}.credits-footer{display:none}}.credits-footer{position:fixed;bottom:16px;right:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 16px;font-size:.75rem;box-shadow:var(--shadow);z-index:100;max-width:200px}.credits-title{font-weight:600;color:var(--text);margin-bottom:8px;font-size:.8rem}.credits-subtitle{font-weight:600;color:var(--text);margin-top:12px;margin-bottom:6px;font-size:.75rem;padding-top:8px;border-top:1px solid var(--border)}.credits-links{display:flex;flex-direction:column;gap:6px}.credits-links a{color:var(--text-secondary);text-decoration:none;transition:all .2s ease;font-size:.75rem}.credits-links a:hover{color:var(--text);text-decoration:underline}
