:root{color-scheme:dark;--bg: #1a0d2a;--bg-2: #261236;--bg-3: #361c4a;--fg: #f4e8c1;--muted: #a892b4;--accent: #d4a945;--accent-soft: rgba(212, 169, 69, .25);--rose: #c97b8a;--danger: #d96874;--border: #3d2351;--paper: #fbf8ec;--serif: "Cormorant Garamond", "Hoefler Text", "Baskerville", Georgia, serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:radial-gradient(ellipse at 50% -10%,rgba(80,40,110,.45),transparent 60%),radial-gradient(ellipse at 110% 90%,rgba(120,70,50,.15),transparent 50%),var(--bg);background-attachment:fixed;color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;overscroll-behavior:none}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}a{color:inherit;text-decoration:none}.loading{display:grid;place-items:center;height:100vh;color:var(--muted);font-family:var(--serif);font-style:italic;font-size:18px}.library{padding:16px;padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom));max-width:900px;margin:0 auto}.library-header{text-align:center;margin-bottom:24px}.library-header:before{content:"✦ ☽ ✦";display:block;color:var(--accent);font-size:12px;letter-spacing:.6em;opacity:.8;margin-bottom:8px;padding-left:.6em}.library-header h1{font-family:var(--serif);font-style:italic;font-weight:500;font-size:36px;color:var(--accent);letter-spacing:.01em;margin:0;text-shadow:0 0 30px rgba(212,169,69,.25)}.upload-form{display:grid;gap:10px;background:linear-gradient(180deg,rgba(212,169,69,.04),transparent),var(--bg-2);padding:16px;border-radius:14px;border:1px solid var(--border);margin-bottom:24px;position:relative}.upload-form:before{content:"✧";position:absolute;top:8px;right:12px;color:var(--accent);opacity:.4;font-size:14px}.upload-form input[type=text],.upload-form button{width:100%;padding:11px 14px;background:#00000040;border:1px solid var(--border);border-radius:9px;color:var(--fg);font-size:16px}.upload-form input[type=text]::placeholder{color:var(--muted);font-style:italic}.upload-form input[type=text]:focus,.upload-form button:focus{outline:none;border-color:var(--accent)}.upload-form button{background:linear-gradient(180deg,#e2b85a,var(--accent));color:#2b1a08;font-weight:600;border-color:transparent;letter-spacing:.02em;box-shadow:0 2px 8px #d4a94533}.upload-form button:disabled{background:#ffffff0f;color:var(--muted);cursor:not-allowed;box-shadow:none}.file-label{display:block;position:relative;padding:11px 14px;border:1px dashed var(--border);border-radius:9px;background:#00000026;color:var(--muted);font-size:14px;text-align:center;cursor:pointer;font-style:italic}.file-label input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.range-label{display:flex;align-items:center;gap:12px;padding:4px 6px 0;font-size:13px;color:var(--muted)}.range-label input{flex:1;accent-color:var(--accent)}.range-label span{min-width:70px;font-variant-numeric:tabular-nums}.hint-suggest{margin:-2px 6px 0;font-size:12px;font-style:italic;color:var(--accent);opacity:.85}.hint-suggest strong{font-style:normal;font-weight:600;color:var(--fg)}.link{color:var(--accent);font-style:italic;text-decoration:underline;padding:0;background:none;border:none;font-size:inherit;cursor:pointer}.error{color:var(--danger);font-size:14px;font-style:italic}.job-list{display:grid;gap:10px;margin-bottom:20px}.job-banner{background:linear-gradient(180deg,rgba(212,169,69,.06),transparent),var(--bg-2);border:1px solid var(--accent-soft);border-radius:12px;padding:12px 14px 10px}.job-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:8px}.job-label{color:var(--fg);font-size:14px}.job-label em{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:16px}.job-pct{color:var(--accent);font-variant-numeric:tabular-nums;font-size:13px}.job-bar{height:4px;background:#f4e8c11a;border-radius:999px;overflow:hidden;margin-bottom:6px}.job-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#e2b85a);border-radius:999px;transition:width .6s ease}.job-stage{color:var(--muted);font-style:italic;font-size:12px}.filter-chips{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none;padding:2px 0}.filter-chips::-webkit-scrollbar{display:none}.filter-chip{padding:6px 14px;font-size:13px;border-radius:999px;border:1px solid var(--border);background:#0003;color:var(--muted);white-space:nowrap;font-family:var(--serif);font-style:italic;transition:background .15s ease,color .15s ease,border-color .15s ease}.filter-chip.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.muted{color:var(--muted);font-style:italic}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}.card{position:relative;background:var(--bg-2);border-radius:14px;overflow:hidden;border:1px solid var(--border);transition:transform .2s ease,border-color .2s ease}.card:hover{border-color:var(--accent-soft);transform:translateY(-1px)}.card-link{display:block}.card img{width:100%;aspect-ratio:1;object-fit:cover;background:#1a0d2a;display:block}.card-meta{padding:9px 11px;display:flex;align-items:center;justify-content:space-between;gap:8px}.card-title{font-family:var(--serif);font-style:italic;font-size:15px;font-weight:500;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.01em}.card-pct{font-size:12px;color:var(--accent);font-variant-numeric:tabular-nums;opacity:.85}.card-menu-wrap{position:absolute;top:6px;right:6px}.card-menu-btn{width:32px;height:32px;border-radius:50%;background:#1a0d2ab3;border:1px solid rgba(212,169,69,.3);color:var(--fg);font-size:22px;line-height:1;display:grid;place-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.card-menu{position:absolute;top:38px;right:0;min-width:170px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 32px #0009;overflow:hidden;z-index:20;display:flex;flex-direction:column}.card-menu button{text-align:left;padding:13px 16px;font-size:14px;color:var(--fg);background:transparent;font-family:var(--serif);font-style:italic}.card-menu button:hover,.card-menu button:focus{background:var(--bg-3)}.card-menu button.danger{color:var(--danger);border-top:1px solid var(--border)}.puzzle{position:fixed;inset:0;background:var(--bg);overflow:hidden}.puzzle-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none;user-select:none;-webkit-user-select:none}.topbar{position:absolute;top:0;left:0;right:0;display:grid;grid-template-columns:50px 1fr 60px;align-items:center;padding:env(safe-area-inset-top) 12px 8px;padding-top:max(env(safe-area-inset-top),8px);background:linear-gradient(180deg,#1a0d2ab3,#1a0d2a00);color:var(--fg);font-size:15px;transition:opacity .25s ease,transform .25s ease;z-index:10}.topbar-title{text-align:center;font-family:var(--serif);font-style:italic;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.02em}.topbar-pct{text-align:right;font-variant-numeric:tabular-nums;color:var(--accent);font-size:13px;padding-right:4px}.back{font-size:22px;line-height:1;width:38px;height:38px;display:grid;place-items:center;border-radius:19px;background:#1a0d2a8c;border:1px solid rgba(212,169,69,.25);color:var(--accent)}.hint-btn{position:absolute;right:14px;bottom:calc(max(env(safe-area-inset-bottom),10px) + 96px);width:42px;height:42px;border-radius:21px;background:#1a0d2ab3;border:1px solid rgba(212,169,69,.35);color:var(--accent);font-size:20px;line-height:1;display:grid;place-items:center;z-index:11;transition:opacity .25s ease,transform .25s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 14px #0006}.hint-btn:active{transform:scale(.92)}.palette{position:absolute;left:0;right:0;bottom:0;padding:10px 8px max(10px,env(safe-area-inset-bottom));background:linear-gradient(0deg,#1a0d2ad9,#1a0d2a00);transition:opacity .25s ease,transform .25s ease;z-index:10}.palette-scroll{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x proximity;padding:4px 4px 8px;-webkit-overflow-scrolling:touch}.palette-scroll::-webkit-scrollbar{display:none}.swatch{position:relative;width:56px;height:56px;flex:0 0 auto;display:grid;place-items:center;scroll-snap-align:center;transition:transform .15s ease,opacity .25s ease;padding:0}.swatch.selected{transform:scale(1.1)}.swatch .ring{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}.swatch .ring-bg{fill:none;stroke:#f4e8c126;stroke-width:2}.swatch .ring-fg{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-linecap:round;transition:stroke-dasharray .25s ease}.swatch.selected .ring-fg{stroke:var(--fg)}.swatch .chip{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:700;color:#000000d9;text-shadow:0 1px 0 rgba(255,255,255,.4);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 6px #00000059}.chrome-hidden{opacity:0;pointer-events:none;transform:translateY(8px)}.topbar.chrome-hidden{transform:translateY(-8px)}.complete-overlay{position:absolute;inset:0;display:grid;place-items:center;background:radial-gradient(ellipse at center,#3c1e5099,#000000d9);z-index:20;padding:24px}.complete-card{background:linear-gradient(180deg,rgba(212,169,69,.06),transparent),var(--bg-2);border:1px solid var(--accent-soft);border-radius:18px;padding:28px 24px 20px;text-align:center;max-width:380px;width:100%;position:relative;box-shadow:0 12px 48px #0009}.complete-card:before{content:"✦  ☽  ✦";display:block;color:var(--accent);font-size:12px;letter-spacing:.6em;opacity:.85;margin-bottom:8px;padding-left:.6em}.complete-card h2{margin:0 0 18px;font-family:var(--serif);font-style:italic;font-size:28px;font-weight:500;color:var(--accent);letter-spacing:.02em}.complete-card img{width:100%;border-radius:10px;background:#000;display:block;margin:0 auto 8px;transition:opacity .25s ease;border:1px solid var(--border)}.complete-card img.hidden{opacity:.18}.hint{color:var(--muted);font-size:12px;margin:0 0 18px;font-style:italic}.complete-actions{display:flex;gap:10px;justify-content:center}.btn{padding:11px 16px;background:#00000040;border-radius:9px;border:1px solid var(--border);color:var(--fg);font-size:14px;font-family:var(--serif);font-style:italic}.btn:hover{border-color:var(--accent-soft)}
