@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300&family=Space+Mono:wght@400;700&family=Noto+Sans+JP:wght@300;400&display=swap");:root{--bg:#0c0c0f;--surface:#141418;--border:hsla(0,0%,100%,.07);--text:#e8e4dc;--muted:#9b8fad;--accent:#c9a8e0;--accent2:#f0c4d4;--accent-subtle:rgba(201,168,224,.08);--transition-theme:background 0.8s ease,color 0.8s ease,border-color 0.8s ease}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:Noto Sans JP,sans-serif;font-weight:300;min-height:100vh;overflow-x:hidden;transition:var(--transition-theme)}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.4}header{padding:40px 64px 28px;justify-content:space-between;border-bottom:1px solid var(--border);transition:var(--transition-theme)}.header-left,header{display:flex;align-items:center}.header-left{gap:20px}.logo{font-family:Cormorant Garamond,serif;font-size:38px;font-weight:300;letter-spacing:.2em;color:var(--text);transition:color .8s ease;text-decoration:none}.logo span{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{font-family:Space Mono,monospace;font-size:10px;color:var(--muted);letter-spacing:.25em;text-transform:uppercase}.nav-tabs{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:3px}.nav-tab{padding:8px 20px;font-family:Space Mono,monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--text);background:none;border:none;cursor:pointer;border-radius:2px;transition:all .2s;text-decoration:none;display:inline-block}.nav-tab.active{background:var(--accent-subtle);color:var(--accent);border:1px solid rgba(201,168,224,.2)}.nav-tab:hover:not(.active){color:var(--text)}#reset-theme-btn,.reset-theme-btn{padding:6px 14px;background:transparent;border:1px solid var(--border);color:var(--muted);font-family:Space Mono,monospace;font-size:10px;letter-spacing:.15em;cursor:pointer;border-radius:2px;transition:all .3s;display:none}.reset-theme-btn:hover{border-color:var(--accent);color:var(--accent)}.reset-theme-btn.visible{display:block}.main-grid{padding:56px 64px;display:grid;grid-template-columns:1fr 1fr;grid-gap:48px;gap:48px;max-width:1400px;margin:0 auto}.drop-zone{border:1px solid var(--border);border-radius:2px;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;background:var(--surface)}.drop-zone:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,224,.04),rgba(240,196,212,.04));opacity:0;transition:opacity .3s}.drop-zone.drag-over:before,.drop-zone:hover:before{opacity:1}.drop-zone.drag-over{border-color:var(--accent)}.drop-icon{width:44px;height:44px;margin-bottom:18px;opacity:.25;color:var(--text)}.drop-text{font-family:Cormorant Garamond,serif;font-size:22px;color:var(--text);margin-bottom:6px;letter-spacing:.05em}.drop-sub{font-family:Space Mono,monospace;font-size:10px;color:var(--muted);opacity:.5;letter-spacing:.15em}.preview-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:none}.preview-img.visible{display:block}.privacy-badge{font-family:Space Mono,monospace;font-size:10px;color:var(--muted);margin-top:10px;letter-spacing:.05em;opacity:.6}.controls{margin-top:16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.control-label{font-family:Space Mono,monospace;font-size:10px;color:var(--text);letter-spacing:.2em;text-transform:uppercase}.count-buttons{display:flex;gap:4px}.count-btn{width:34px;height:32px;background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:Space Mono,monospace;font-size:11px;cursor:pointer;transition:all .2s;border-radius:2px}.count-btn.active,.count-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.extract-btn{margin-top:14px;width:100%;padding:13px;background:transparent;border:1px solid rgba(201,168,224,.35);color:var(--accent);font-family:Space Mono,monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:all .3s;border-radius:2px}.extract-btn:hover:not(:disabled){background:var(--accent-subtle);border-color:var(--accent)}.extract-btn:disabled{opacity:.25;cursor:not-allowed}.results-panel{display:flex;flex-direction:column;gap:20px}.palette-bar{display:flex;height:100px;border-radius:2px;overflow:hidden;border:1px solid var(--border)}.palette-swatch{flex:1 1;transition:flex .4s cubic-bezier(.23,1,.32,1);cursor:pointer;position:relative}.palette-swatch:hover{flex:2 1}.swatch-hex{position:absolute;bottom:7px;left:50%;transform:translateX(-50%);font-family:Space Mono,monospace;font-size:8px;white-space:nowrap;opacity:0;transition:opacity .2s;letter-spacing:.08em;text-shadow:0 1px 4px rgba(0,0,0,.9)}.palette-swatch:hover .swatch-hex{opacity:1}.color-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-gap:10px;gap:10px}.color-card{background:var(--surface);border:1px solid var(--border);border-radius:2px;overflow:hidden;cursor:pointer;transition:transform .2s,border-color .2s;position:relative}.color-card:hover{transform:translateY(-2px);border-color:hsla(0,0%,100%,.14)}.color-card .copied-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:Space Mono,monospace;font-size:9px;letter-spacing:.2em;background:rgba(0,0,0,.55);color:var(--text);animation:fadeOut 1s .5s forwards}@keyframes fadeOut{to{opacity:0}}.card-swatch{height:72px}.card-info{padding:9px 11px}.card-hex{font-size:11px;letter-spacing:.04em}.card-hex,.card-rgb{font-family:Space Mono,monospace;color:var(--text);transition:color .8s}.card-rgb{font-size:9px;margin-top:3px;opacity:.7}.apply-section{display:flex;gap:10px}.apply-btn{flex:1 1;padding:11px;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;color:#1a1018;font-family:Space Mono,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:all .3s;border-radius:2px;font-weight:700}.apply-btn:hover{opacity:.85;transform:translateY(-1px)}.apply-btn:disabled{opacity:.25;cursor:not-allowed;transform:none}.section-label{font-family:Space Mono,monospace;font-size:10px;color:var(--text);letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px}.export-tabs{display:flex;gap:2px;margin-bottom:10px}.tab-btn{padding:6px 14px;background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:Space Mono,monospace;font-size:10px;letter-spacing:.1em;cursor:pointer;transition:all .2s;border-radius:2px}.tab-btn.active,.tab-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.export-code{background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:14px 14px 14px 16px;font-size:10px;line-height:1.9;white-space:pre;overflow-x:auto;position:relative;transition:var(--transition-theme)}.copy-btn,.export-code{font-family:Space Mono,monospace;color:var(--accent)}.copy-btn{position:absolute;top:8px;right:8px;padding:3px 9px;background:var(--accent-subtle);border:1px solid rgba(201,168,224,.25);font-size:8px;letter-spacing:.1em;cursor:pointer;border-radius:2px;transition:background .2s}.copy-btn:hover{background:rgba(201,168,224,.2)}.tag-row{display:flex;flex-wrap:wrap;gap:6px}.tag{padding:4px 12px;border:1px solid var(--border);border-radius:20px;font-family:Space Mono,monospace;font-size:10px;color:var(--text);letter-spacing:.1em;transition:var(--transition-theme)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:320px;gap:14px;opacity:.25}.empty-state-text{font-family:Cormorant Garamond,serif;font-size:20px;font-style:italic;color:var(--muted)}.empty-state-sub{font-family:Space Mono,monospace;font-size:10px;color:var(--muted);letter-spacing:.2em}.theme-flash{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:0;transition:opacity .15s}.theme-flash.active{opacity:.12}.count-btn.locked,.tab-btn.locked{position:relative;opacity:.45}.count-btn.locked:after,.tab-btn.locked:after{content:"\2726";position:absolute;top:-5px;right:-5px;font-size:7px;color:var(--accent2);line-height:1}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border:1px solid hsla(0,0%,100%,.1);border-radius:3px;width:420px;max-width:90vw;padding:40px;position:relative;transform:translateY(12px);transition:transform .3s cubic-bezier(.23,1,.32,1)}.modal-overlay.open .modal{transform:translateY(0)}.modal-close{position:absolute;top:16px;right:16px;width:28px;height:28px;background:none;border:1px solid var(--border);color:var(--muted);font-size:14px;cursor:pointer;border-radius:2px;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{border-color:var(--accent);color:var(--accent)}.modal-eyebrow{font-family:Space Mono,monospace;font-size:9px;letter-spacing:.3em;color:var(--accent);text-transform:uppercase;margin-bottom:12px}.modal-title{font-family:Cormorant Garamond,serif;font-size:30px;letter-spacing:.05em;margin-bottom:10px;line-height:1.2}.modal-desc,.modal-title{font-weight:300;color:var(--text)}.modal-desc{font-family:Noto Sans JP,sans-serif;font-size:14px;line-height:1.7;margin-bottom:28px;opacity:.8}.google-btn{width:100%;padding:13px;background:#fff;border:none;border-radius:2px;color:#333;font-family:Space Mono,monospace;font-size:11px;letter-spacing:.12em;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:opacity .2s;font-weight:700}.google-btn:hover{opacity:.9}.modal-note{font-family:Space Mono,monospace;font-size:9px;color:var(--muted);text-align:center;letter-spacing:.1em;line-height:1.6;margin-top:14px;opacity:.7}.price-display{display:flex;align-items:baseline;gap:6px;margin-bottom:20px}.price-amount{font-family:Cormorant Garamond,serif;font-size:52px;font-weight:300;color:var(--text);line-height:1}.price-currency{font-size:14px}.price-currency,.price-type{font-family:Space Mono,monospace;color:var(--muted);margin-bottom:4px}.price-type{font-size:9px;letter-spacing:.15em}.feature-list{list-style:none;margin-bottom:28px;display:flex;flex-direction:column;gap:8px}.feature-list li{display:flex;align-items:center;gap:10px;font-family:Noto Sans JP,sans-serif;font-size:13px;color:var(--text);font-weight:300}.feature-list li:before{content:"\2726";font-size:8px;color:var(--accent);flex-shrink:0}.stripe-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:2px;color:#1a1018;font-family:Space Mono,monospace;font-size:11px;letter-spacing:.2em;font-weight:700;cursor:pointer;transition:opacity .2s,transform .2s}.stripe-btn:hover{opacity:.88;transform:translateY(-1px)}.stripe-note{justify-content:center;gap:6px;margin-top:12px;font-size:8px;color:var(--muted);opacity:.6}.stripe-note,.user-bar{display:flex;align-items:center;font-family:Space Mono,monospace;letter-spacing:.1em}.user-bar{gap:10px;padding:6px 12px;background:var(--accent-subtle);border:1px solid rgba(201,168,224,.2);border-radius:2px;font-size:10px;color:var(--accent)}.user-avatar{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));font-size:9px;color:#1a1018;font-weight:700;flex-shrink:0}.site-footer,.user-avatar{display:flex;align-items:center;justify-content:center}.site-footer{padding:24px 64px;border-top:1px solid var(--border);gap:16px;font-family:Space Mono,monospace;font-size:10px;color:var(--muted);letter-spacing:.1em}.site-footer a{color:var(--muted);text-decoration:none;transition:color .2s}.site-footer a:hover{color:var(--accent)}@media (max-width:900px){.main-grid{grid-template-columns:1fr;padding:32px 24px}header{padding:28px 24px}}