:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;overflow:hidden}h1{font-size:1.8em;line-height:1.1;margin:0 0 10px;color:#ff69b4}h2{font-size:1.5em;margin:20px 0 15px;color:#87ceeb}h3{font-size:1.1em;margin:20px 0 15px;color:#87ceeb;font-weight:600}#app{height:100vh;width:100vw;overflow:hidden}.app-layout{display:flex;height:100vh;width:100vw}.sidebar{width:350px;background:#ffffff0d;border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center;flex-shrink:0}.sidebar-content{flex:1;overflow-y:auto;padding:20px}.main-content{flex:1;overflow:auto;background:#0a0a0a;display:flex;align-items:center;justify-content:center}.placeholder{text-align:center;color:#ffffff4d;font-size:1.2em}.subtitle{color:#999;margin-bottom:0;font-size:.9em}.upload-section{margin:0 0 20px}.btn-primary{border-radius:8px;border:1px solid transparent;padding:12px 24px;font-size:1em;font-weight:600;font-family:inherit;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;transition:all .3s;width:100%}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-primary:not(:disabled):active{transform:translateY(0)}.btn-secondary{border-radius:8px;border:2px solid #667eea;padding:10px 20px;font-size:.9em;font-weight:600;font-family:inherit;background:transparent;color:#667eea;cursor:pointer;transition:all .3s;width:100%;margin-bottom:10px}.btn-secondary:hover{background:#667eea;color:#fff}.controls,.result-controls{background:#ffffff08;border-radius:12px;padding:15px;margin:0 0 20px}.control-group{margin:15px 0}.control-group label{font-weight:600;display:block;margin-bottom:8px;font-size:.9em}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;margin-bottom:12px;font-size:.9em}.range-wrapper{display:flex;align-items:center;gap:10px}.control-group input[type=range]{flex-grow:1;height:6px;background:#ffffff1a;border-radius:5px;outline:none;-webkit-appearance:none}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer}.control-group input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;border:none}.control-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.control-group span{min-width:30px;text-align:center;font-weight:600;color:#667eea;font-size:.9em}.action-buttons{margin-top:15px}.orientation-buttons{display:flex;gap:8px;margin-top:8px}.btn-orientation{flex:1;padding:8px 16px;border:2px solid rgba(102,126,234,.5);background:transparent;color:#ffffffb3;border-radius:6px;cursor:pointer;font-size:.85em;font-weight:600;transition:all .3s}.btn-orientation:hover{border-color:#667eea;color:#fff}.btn-orientation.active{background:#667eea;border-color:#667eea;color:#fff}.result-section{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px}#gridCanvas{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px #00000080}.color-palette{background:#ffffff08;border-radius:12px;padding:15px;margin:0;display:none}.palette-items{display:flex;flex-direction:column;gap:8px;margin-top:10px}.palette-item{display:flex;align-items:center;gap:8px;background:#ffffff0d;padding:8px;border-radius:6px;transition:background .2s}.palette-item:hover{background:#ffffff1a}.color-swatch{width:30px;height:30px;border-radius:4px;border:2px solid rgba(255,255,255,.3);flex-shrink:0}.color-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px;flex-grow:1;min-width:0}.color-number{font-weight:700;font-size:.9em;color:#667eea}.color-code{font-size:.75em;font-weight:600;color:#ff69b4;background:#ff69b426;padding:2px 4px;border-radius:3px;font-family:monospace}.color-name{font-size:.85em;color:#ffffffe6}.color-hex{font-size:.75em;color:#fff9;font-family:monospace}.color-count{font-size:.7em;color:#ffffff80;font-style:italic}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#f5f5f5}.subtitle{color:#666}.sidebar{background:#00000008;border-right:1px solid rgba(0,0,0,.1)}.sidebar-header{border-bottom:1px solid rgba(0,0,0,.1)}.main-content{background:#fff}.placeholder{color:#0000004d}.controls,.result-controls,.color-palette,.palette-item{background:#00000008}.palette-item:hover{background:#00000014}.color-name{color:#000000e6}.color-hex,.color-count{color:#0009}.color-code{background:#ff69b433}.control-group input[type=range]{background:#0000001a}}@media(max-width:768px){.app-layout{flex-direction:column}.sidebar{width:100%;height:auto;max-height:50vh}.sidebar-content{max-height:calc(50vh - 120px)}h1{font-size:1.5em}.palette-items{grid-template-columns:1fr}}
