:root{--bg: #f6f7fb;--bg-elev: #ffffff;--ink: #161b26;--ink-soft: #5c667b;--ink-faint: #8b94a6;--accent: #2d6df6;--accent-2: #04a58f;--muted: #edf1f8;--radius-xl: 20px;--radius-lg: 14px;--radius-md: 10px;--radius-sm: 8px;--shadow: 0 16px 42px rgba(15, 25, 45, .12);--shadow-soft: 0 6px 20px rgba(15, 25, 45, .08);--glass: rgba(255, 255, 255, .74);--glass-strong: rgba(255, 255, 255, .96);--line: rgba(22, 30, 46, .11)}*{box-sizing:border-box}body{margin:0;font-family:Plus Jakarta Sans,Manrope,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(900px 460px at -10% 0%,rgba(45,109,246,.1),transparent 60%),radial-gradient(700px 400px at 100% 0%,rgba(4,165,143,.08),transparent 64%),linear-gradient(180deg,#f9fbff,#f2f5fb);min-height:100vh;letter-spacing:0}h1,h2,h3{font-family:Space Grotesk,Plus Jakarta Sans,sans-serif;margin:0;letter-spacing:-.02em}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{width:280px;padding:32px 24px;background:linear-gradient(180deg,#1f2533,#232b3d),radial-gradient(500px 260px at 0% 0%,rgba(74,123,242,.3),transparent 68%);color:#e8eefc;border-right:1px solid rgba(255,255,255,.09);box-shadow:0 0 0 1px #ffffff08 inset,12px 0 28px #080c1838;display:flex;flex-direction:column;gap:16px}.sidebar-top-controls{display:flex;justify-content:flex-start;align-items:center;gap:8px;margin-bottom:4px}.sidebar h1{font-size:28px;margin-bottom:6px}.sidebar-header{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.sidebar-title{display:grid;gap:6px}.sidebar-logo-wrap{margin:-27px -24px 0;padding:5px 7px;display:flex;justify-content:center}.sidebar-logo{width:min(180px,100%);height:auto;object-fit:contain}.sidebar-total{font-size:13px;color:#e2ecffe0;background:#ffffff1a;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14)}.icon-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:50%;font-size:16px}.collapse-btn{padding:6px 12px}.theme-toggle-btn{min-width:46px}.sidebar.collapsed{width:72px;padding:20px 12px}.sidebar.collapsed h1,.sidebar.collapsed .pill,.sidebar.collapsed .sidebar-account,.sidebar.collapsed .sidebar-total{display:none}.sidebar.collapsed .sidebar-top-controls{justify-content:center;flex-direction:column}.nav-group{display:grid;gap:10px;margin:12px 0 18px}.nav-item-content{display:inline-flex;align-items:center;justify-content:flex-start;gap:10px;width:100%}.nav-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;line-height:1}.nav-label{white-space:nowrap}.nav-spacer{height:12px}.ghost-btn.active{border-color:#0f6bff59;box-shadow:0 10px 20px #0f6bff26}.sidebar .ghost-btn{background:#ffffff1a;color:#f0f5ff;border-color:#ffffff29;box-shadow:none}.sidebar .ghost-btn.active{background:linear-gradient(135deg,#2d6df659,#04a58f4d);border-color:#a0d0ff9e;color:#fff}.sidebar .pill{background:#ffffff1a;padding:10px 14px;border-radius:999px;margin-bottom:12px;font-size:13px;color:#dde7fccc;border:1px solid rgba(255,255,255,.14)}.sidebar-account{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;padding:12px;border-radius:18px;background:#ffffff1a;border:1px solid rgba(255,255,255,.14);box-shadow:none}.avatar{width:44px;height:44px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7bb4ff,#7de6da);color:#0b2446;font-weight:700}.settings-section{display:grid;gap:20px}.settings-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-card{background:#ffffffd9;border-radius:22px;padding:18px;box-shadow:var(--shadow-soft);display:grid;gap:14px}.settings-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;align-items:center}.settings-error{font-size:13px;color:#b94545}.settings-list{display:grid;gap:14px}.settings-user{display:grid;gap:12px;padding:14px;border-radius:16px;background:#f8faffe6;border:1px solid rgba(190,200,220,.4)}.settings-user-title{display:inline-flex;align-items:center;gap:8px}.settings-user-meta{font-size:12px;color:var(--ink-soft)}.settings-user-perms{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px 12px}.perm-toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink)}.settings-user-actions{display:flex;justify-content:flex-end}.admin-users-head{display:grid;grid-template-columns:1fr minmax(260px,380px);gap:10px;align-items:center}.admin-users-head--audit{grid-template-columns:1fr minmax(520px,1fr)}.admin-audit-filters{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:8px;align-items:center}.admin-audit-filters .input{min-width:150px}.admin-audit-filters .input[type=text]{min-width:230px}.admin-users-table-wrap{overflow:auto;border:1px solid rgba(190,200,220,.55);border-radius:14px;background:#fcfdffe6}.admin-users-table{width:100%;border-collapse:collapse;font-size:13px}.admin-users-table th,.admin-users-table td{border-bottom:1px solid rgba(190,200,220,.38);padding:8px 10px;text-align:left;white-space:nowrap}.admin-users-table th{position:sticky;top:0;z-index:1;background:#f5f9fffa;color:var(--ink-soft);font-weight:600}.admin-users-table tbody tr:hover{background:#f2f8ffbf}.admin-users-table .row-blocked{background:#ffebeb6b}.admin-user-cell{display:inline-flex;align-items:center;gap:8px}.perm-toggle.compact{justify-content:center}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.ghost-btn.danger{color:#a13131;border-color:#a1313147}.ghost-btn.danger:hover{background:#a131311a}@media (max-width: 1024px){.admin-users-head,.admin-users-head--audit{grid-template-columns:1fr}.admin-audit-filters{justify-content:stretch}.admin-audit-filters .input,.admin-audit-filters .input[type=text],.admin-audit-filters .ghost-btn{width:100%;min-width:0}}.account-meta{display:grid;gap:4px}.account-name{font-weight:600;font-size:14px;color:#f3f7ff}.account-sub{font-size:12px;color:#e0eafcb8}.account-actions{display:inline-flex;align-items:center;gap:6px}.sidebar-footer{margin-top:auto;display:flex;justify-content:flex-start}.sidebar.collapsed .nav-group{margin:8px 0 12px;gap:8px}.sidebar.collapsed .nav-group .ghost-btn{padding:10px 0;display:flex;justify-content:center}.sidebar.collapsed .nav-item-content{justify-content:center;gap:0}.sidebar.collapsed .nav-icon{width:auto}.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed .nav-spacer{height:6px}.sidebar.collapsed .sidebar-footer{justify-content:center}.main{flex:1;padding:34px 42px 62px}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px}.login-card{width:min(520px,100%);background:var(--glass-strong);border-radius:28px;padding:36px 32px;box-shadow:var(--shadow);text-align:center;display:grid;gap:12px}.login-card h1{font-size:34px}.login-card h2{font-size:20px}.login-card p{margin:0 0 10px;color:var(--ink-soft)}.community-banner{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center;padding:12px 16px;margin-bottom:18px;border-radius:var(--radius-lg);background:#ffffffe6;border:1px solid var(--line);box-shadow:var(--shadow-soft);font-size:12px;color:var(--ink-soft)}.community-banner a{color:var(--accent);font-weight:600;text-decoration:none}.top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:18px 18px 16px;border-radius:var(--radius-xl);border:1px solid var(--line);background:radial-gradient(520px 220px at 8% -5%,rgba(45,109,246,.12),transparent 62%),linear-gradient(180deg,#fffffffa,#f8fbfff2);box-shadow:var(--shadow-soft)}.top-bar h2{font-size:38px;font-weight:700;margin-bottom:4px}.actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.primary-btn,.ghost-btn{border-radius:10px;padding:9px 14px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease;font-weight:600;letter-spacing:.01em}.primary-btn{border:1px solid rgba(23,84,219,.2);background:linear-gradient(135deg,#2d6df6,#5694ff 60%,#5dc4e4);color:#fff;box-shadow:0 10px 18px #2d6df642}.primary-btn:disabled,.primary-btn.disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.primary-btn:hover{transform:translateY(-1px)}.ghost-btn{background:#ffffffe6;color:var(--ink);border:1px solid var(--line);box-shadow:0 1px 6px #0a16280d}.ghost-btn:hover{transform:translateY(-1px);border-color:#1365f166}.ghost-btn:disabled,.ghost-btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.range-gradient{background:linear-gradient(90deg,#ffd3c1,#ffe29a,#d3f1a4,#9ed0ff,#c5a5ff,#ffb3e6)}.range-gradient::-webkit-slider-runnable-track{background:transparent}.range-gradient::-moz-range-track{background:transparent}.ghost-btn.tiny{padding:6px 11px;font-size:12px;border-radius:10px}.ghost-btn.tiny.active{border-color:#0f6bff73;background:#0f6bff1f;color:#0f6bff}.recent-block{margin-top:16px;padding:12px;border-radius:16px;background:#ffffffbf;box-shadow:var(--shadow-soft)}.recent-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.recent-chip{display:grid;grid-template-columns:18px 1fr;align-items:center;gap:8px;border:1px solid rgba(15,25,40,.12);border-radius:12px;background:#fff;padding:6px 10px;font-size:12px;cursor:pointer;text-align:left}.recent-chip span{width:16px;height:16px;border-radius:6px;border:1px solid rgba(15,25,40,.1)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(244px,1fr));gap:14px}.paint-card{background:linear-gradient(180deg,#fffffff7,#f6faffed);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease}.paint-card .card-title-line{font-size:17px;line-height:1.2}.paint-card .card-code{font-size:12px;letter-spacing:.04em}.inventory-indicator{position:absolute;top:10px;right:10px;width:24px;height:24px;border-radius:999px;background:#ffffffeb;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 14px #0f192824;border:1px solid rgba(15,25,40,.08);z-index:2}.inventory-indicator-dot{width:10px;height:10px;border-radius:999px}.inventory-indicator--owned .inventory-indicator-dot{background:#ff4545;border:1px solid #e03a3a}.inventory-indicator--planned .inventory-indicator-dot{background:#ffd348;border:1px solid #dfb633}.inventory-indicator--none .inventory-indicator-dot{background:transparent;border:1px solid rgba(15,25,40,.45)}.inventory-indicator--mixed .inventory-indicator-dot{background:linear-gradient(90deg,#ff4545 0,#ff4545 50%,#ffd348 50%,#ffd348);border:1px solid rgba(15,25,40,.25)}.inventory-indicator-button{cursor:pointer}.inventory-indicator-button:disabled{cursor:not-allowed;opacity:.55}.icon-muted{opacity:.45}.table-state{display:inline-flex;width:20px;height:20px;align-items:center;justify-content:center;border-radius:6px;border:1px solid rgba(15,25,40,.1);margin-right:6px;opacity:.35;background:#fffc}.table-state.active{opacity:1;background:#0f6bff14;border-color:#0f6bff33}.paint-card.selectable{cursor:pointer}.paint-card.selectable:hover{transform:translateY(-2px);box-shadow:0 18px 32px #0f192824}.paint-card.selectable.selected{border:1px solid rgba(15,107,255,.35);box-shadow:0 18px 34px #0f6bff38}.paint-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.6),transparent 60%);pointer-events:none}.paint-card:hover{transform:translateY(-1px);box-shadow:0 12px 22px #0a162821}.swatch-pair{display:grid;grid-template-columns:1fr 1fr;gap:10px}.swatch-pair.single{grid-template-columns:1fr}.swatch{height:110px;border-radius:18px;display:flex;align-items:flex-end;padding:12px;color:#ffffffb3;font-size:12px;box-shadow:inset 0 1px #ffffff40;overflow:hidden;position:relative}.image-swatch{align-items:center;justify-content:center;color:#0a0e1480}.image-swatch img{width:100%;height:100%;object-fit:cover;border-radius:14px}.swatch span{background:#00000040;padding:4px 8px;border-radius:999px;position:relative;z-index:1}.swatch--contrast:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#ffffffb3,#ffffff38 26%,#0000 50%,#0000008a 72%,#000c);mix-blend-mode:soft-light;pointer-events:none}.swatch--metallic:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 35% 30%,#ffffffbf,#fff0 42%),linear-gradient(115deg,#ffffff73,#fff0,#00000038 70%,#00000061),linear-gradient(90deg,#ffffff26,#fff0 48%,#00000040),radial-gradient(circle at 78% 80%,#0000004d,#0000 55%);mix-blend-mode:soft-light;pointer-events:none}.swatch--wash:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffff0f,#00000061 58%,#000000f2),radial-gradient(circle at 70% 25%,#ffffff1a,#fff0 55%);mix-blend-mode:soft-light;pointer-events:none}.card-title{font-weight:600;font-size:15px;line-height:1.35}.card-title-stack{display:grid;gap:4px}.card-title-line{font-weight:600;color:var(--ink)}.card-code{font-size:13px;color:var(--ink-soft)}.card-name{font-size:15px;color:var(--ink)}.card-sub{color:var(--ink-soft);font-size:12px}.paint-dates{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:11px;color:var(--ink-faint)}.paint-date-sep{opacity:.6}.card-remove{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:999px;border:1px solid rgba(15,25,40,.12);background:#ffffffe6;color:var(--ink-soft);font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 16px #0f19281f;transition:transform .15s ease,box-shadow .15s ease,color .15s ease}.card-remove:hover{transform:translateY(-1px);color:var(--ink);box-shadow:0 12px 18px #0f192829}.paint-distance{font-size:12px;color:var(--ink-soft)}.badge-row{display:flex;gap:8px;flex-wrap:wrap}.tag-row{display:flex;flex-wrap:wrap;gap:6px}.tag-chip{font-size:11px;color:#2f5b3d;background:#78c88c2e;border:1px solid rgba(120,200,140,.35);padding:4px 8px;border-radius:999px}.analog-list{display:grid;gap:6px;font-size:12px;color:var(--ink-soft)}.analog-item{padding:6px 8px;background:#ffffffb3;border-radius:10px;border:1px solid rgba(15,25,40,.06)}.analog-table{display:grid;gap:10px;margin-top:10px}.analog-row{display:grid;grid-template-columns:1.2fr 1fr .8fr 1.6fr 1fr 1.2fr .9fr auto;gap:8px;align-items:center}.analog-head{font-size:12px;color:var(--ink-soft);font-weight:600}.analog-head span{padding:0 4px}.painting-layout{display:grid;grid-template-columns:320px 1fr;gap:18px;align-items:start;min-width:0}.painting-side{display:grid;gap:16px;align-content:start;min-width:0;align-self:start;max-width:100%}.execution-panel{background:#ffffffd9;border-radius:18px;padding:16px;box-shadow:var(--shadow-soft);display:grid;gap:12px}.execution-header{display:grid;gap:8px}.execution-add{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.execution-list{display:grid;gap:8px}.execution-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border-radius:12px;background:#ffffffd9;border:1px solid rgba(15,25,40,.08);cursor:pointer}.execution-item.active{border-color:#0f6bff59;box-shadow:0 10px 18px #0f6bff1f}.point-panel{display:grid;gap:12px;background:#fffc;border-radius:18px;padding:16px;box-shadow:var(--shadow-soft)}.palette-block{background:linear-gradient(180deg,#fffffffa,#f6fafff5);border-radius:var(--radius-xl);border:1px solid var(--line);padding:18px;box-shadow:0 16px 34px #0a16281c}.palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.photo-card{position:relative;display:flex;flex-direction:column;gap:8px;padding:8px;border-radius:16px;overflow:hidden;background:#fff;box-shadow:var(--shadow-soft)}.photo-card img{width:100%;height:140px;object-fit:cover;border-radius:12px;display:block;cursor:pointer}.photo-edit-btn{align-self:flex-start;padding:6px 12px;font-size:12px}.photo-card .icon-btn{position:absolute;top:8px;right:8px;background:#ffffffe6}.reference-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.reference-card{position:relative;border-radius:16px;overflow:hidden;background:#fff;box-shadow:var(--shadow-soft);cursor:pointer;border:1px solid transparent}.reference-card.active{border-color:#0f6bff73;box-shadow:0 12px 22px #0f6bff33}.reference-card img{width:100%;height:110px;object-fit:cover;display:block}.reference-label{font-size:12px;padding:6px 10px 10px;color:var(--ink-soft)}.reference-card .icon-btn{position:absolute;top:6px;right:6px;background:#ffffffe6}.reference-badge{margin-left:8px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:999px;background:#0f6bff1f;color:#0f6bff;font-size:11px;font-weight:600;padding:0 6px}.palette-point-badges{display:flex;flex-wrap:wrap;gap:6px}.point-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:999px;background:#0f6bff1f;color:#0f6bff;font-size:11px;font-weight:600;padding:0 6px}.gallery-modal{background:#fffffffa;border-radius:20px;padding:16px;max-width:90vw;max-height:90vh;width:100%;box-shadow:var(--shadow);display:grid;gap:12px}.gallery-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:space-between}.gallery-nav{display:flex;gap:8px}.gallery-close{width:32px;height:32px;border-radius:50%}.editor-close{padding:8px 14px;border-radius:14px}.gallery-zoom{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-soft)}.gallery-frame{background:#f6f7fb;border-radius:16px;overflow:auto;max-height:70vh;display:flex;align-items:center;justify-content:center;padding:12px}.gallery-frame img{max-width:100%;max-height:100%;transform-origin:center}.palette-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.settings-panel{display:grid;gap:12px}.toggle-group{display:inline-flex;gap:8px;align-items:center;flex-wrap:wrap}.toggle-chip{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#ffffffeb;border-radius:999px;height:32px;padding:0 12px;font-size:12px;font-weight:600;line-height:1;white-space:nowrap;cursor:pointer}.toggle-chip.active{border-color:#1365f180;background:#1365f124;color:#114fc2}input[type=range][disabled]{opacity:.4;cursor:not-allowed}.palette-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.palette-card .swatch{height:90px}.palette-columns{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:16px}.palette-column{display:grid;gap:12px}.palette-header{font-weight:600;font-size:14px;color:var(--ink)}.palette-stack{display:grid;gap:12px}.palette-rows{display:grid;gap:14px}.palette-row{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:16px}.palette-row-header{align-items:end}.palette-cell{display:grid;gap:8px}.painting-list{background:linear-gradient(180deg,#fffffff7,#f5f9fff0);border-radius:var(--radius-xl);border:1px solid var(--line);padding:18px;box-shadow:0 16px 34px #0a16281c;display:grid;gap:10px;height:fit-content}.tolerance-panel{background:#fffc;border-radius:18px;padding:14px 16px;box-shadow:var(--shadow-soft);display:grid;gap:10px}.tolerance-panel .slider{display:grid;gap:8px}.painting-list-header{display:flex;justify-content:space-between;align-items:center}.painting-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,25,40,.1);background:#ffffffe6;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.painting-item:hover{transform:translateY(-1px);border-color:#1365f14d;box-shadow:0 10px 18px #1365f11f}.painting-item .input{padding:6px 8px;font-size:13px;height:30px}.session-actions{display:inline-flex;align-items:center;gap:6px}.session-actions .icon-btn{width:28px;height:28px;border-radius:10px;border:1px solid rgba(15,25,40,.12);background:#ffffffe6;cursor:pointer}.session-actions .icon-btn.delete{color:var(--ink-soft)}.painting-item.active{border-color:#0f6bff59;box-shadow:0 10px 20px #0f6bff1f}.painting-item .delete{color:var(--ink-soft)}.painting-main{display:grid;gap:16px;align-content:start;align-self:start;min-width:0}.painting-toolbar{display:flex;flex-direction:column;gap:12px;align-items:stretch;padding:14px;border-radius:var(--radius-lg);border:1px solid var(--line);background:#ffffffe0;box-shadow:0 10px 22px #0a162817}.upload-progress{display:grid;gap:8px;padding:10px 12px;border-radius:14px;background:#ffffffbf;box-shadow:var(--shadow-soft);font-size:13px;color:var(--ink-soft)}.upload-progress-row{display:grid;grid-template-columns:110px 1fr 40px;align-items:center;gap:8px}.upload-progress-bar{height:8px;border-radius:999px;background:#0f172a1f;overflow:hidden}.upload-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#3b82f6b3,#6366f1e6);transition:width .2s ease}.toolbar-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;width:100%}.painting-canvas{background:radial-gradient(420px 260px at 100% 0%,rgba(19,179,161,.08),transparent 60%),linear-gradient(180deg,#fffffffa,#f6fafff2);padding:18px;border-radius:var(--radius-xl);border:1px solid var(--line);box-shadow:0 20px 36px #0a16281f;text-align:center}.planning-image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;align-items:start}.planning-image-grid.full{grid-template-columns:1fr}.planning-image-panel{display:flex;flex-direction:column;gap:10px;justify-items:center;border-radius:var(--radius-lg);border:1px solid rgba(15,25,40,.08);background:#ffffffbd;padding:10px}.panel-label{font-size:11px;color:#375078;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:#1365f11a;border:1px solid rgba(19,101,241,.16);border-radius:999px;padding:6px 10px;align-self:flex-start}.panel-controls{width:100%;display:grid;gap:6px}.panel-controls.placeholder{visibility:hidden}.panel-image{width:100%;display:flex;justify-content:center}.planning-image-grid.compact .panel-image{margin-top:auto}.planning-image-grid.compact .panel-controls{min-height:150px}.planning-image-grid.compact .panel-label{min-height:22px}.panel-controls .slider{display:grid;grid-template-columns:minmax(120px,140px) 1fr;align-items:center}.panel-controls .slider span{text-align:left}.panel-controls .slider input[type=range]{width:100%}.slider.mini{font-size:12px}.inline-check{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;-webkit-user-select:none;user-select:none}.inline-check input{cursor:pointer}.help-tip{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:12px;font-weight:700;color:var(--ink-soft);border:1px solid rgba(15,25,40,.2);background:#ffffffe6;cursor:help;position:relative}.help-tip:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);padding:10px 12px;border-radius:12px;background:#121822eb;color:#fff;font-size:12px;line-height:1.35;width:320px;max-width:70vw;white-space:pre-line;box-shadow:0 12px 24px #0003;opacity:0;pointer-events:none;transition:opacity .15s ease;z-index:10}.help-tip:hover:after{opacity:1}.wheel-schemes .scheme-btn{display:inline-flex;align-items:center;gap:8px}.wheel-schemes .scheme-btn .help-tip{margin-left:2px}.reference-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px;align-items:start;justify-items:stretch}.reference-grid .painting-image-wrap{width:fit-content;display:block}.reference-grid .painting-image-wrap.full{width:100%}.reference-delete{position:absolute;top:8px;right:8px;background:#ffffffe6}.painting-image-wrap{position:relative;border-radius:18px;overflow:hidden;cursor:crosshair;display:inline-block;max-width:100%;-webkit-user-select:none;user-select:none;border:1px solid rgba(15,25,40,.12);box-shadow:0 14px 24px #08142824}.painting-image-wrap img{display:block;height:auto;max-width:100%;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.painting-image-wrap.compact img{width:auto;max-height:520px}.painting-image-wrap.full img{width:100%}.paint-point{position:absolute;transform:translate(-50%,-50%);width:32px;height:32px;border-radius:50%;background:#0f6bffe6;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;border:2px solid white;cursor:grab;-webkit-user-select:none;user-select:none}.paint-point.active{background:#ffb020e6}.legend{display:grid;gap:8px}.legend-item{display:flex;align-items:center;gap:12px;background:#ffffffd9;padding:10px 12px;border-radius:12px;border:1px solid rgba(15,25,40,.08);cursor:pointer;flex-wrap:wrap;max-width:100%}.legend-main{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.paint-search-results{display:grid;gap:6px;margin-top:6px}.paint-search-item{display:grid;grid-template-columns:18px 1fr auto auto;gap:8px;align-items:center;text-align:left;border:1px solid rgba(15,25,40,.12);border-radius:10px;padding:6px 10px;background:#ffffffeb;cursor:pointer;font-size:12px}.paint-search-swatch{width:16px;height:16px;border-radius:6px;border:1px solid rgba(15,25,40,.1)}.paint-search-title{color:var(--ink)}.paint-search-hex{color:var(--ink-soft);font-size:11px}.paint-search-flag{color:var(--accent);font-weight:600}.role-toggle{display:inline-flex;gap:6px}.role-chip{border:1px solid rgba(0,0,0,.12);background:#fff;border-radius:999px;padding:4px 8px;font-size:12px;cursor:pointer}.role-chip.active{border-color:#0f6bff80;background:#0f6bff1f;color:#0f6bff}.legend-item.active{border-color:#0f6bff59}.legend-color{width:18px;height:18px;border-radius:6px;border:1px solid rgba(15,25,40,.1)}.legend-actions{margin-left:auto;display:flex;align-items:center;gap:6px}.icon-btn{width:28px;height:28px;border-radius:999px;border:1px solid rgba(15,25,40,.12);background:#fff;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;transition:transform .12s ease,border-color .2s ease,background .2s ease,color .2s ease}.icon-btn:active{transform:scale(.94)}.icon-btn.locked{border-color:#0f6bff73;background:#0f6bff1f;color:#0f6bff}.drag-handle{cursor:grab}.drag-handle:active{cursor:grabbing}.slider{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--ink-soft)}.select-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-soft);margin-bottom:8px}.point-label{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:12px}.point-role{font-size:10px;opacity:.8}.point-source{margin-left:8px;font-size:11px;color:var(--ink-soft)}.suggestion-row{display:grid;gap:8px;margin-top:10px}.suggestion-card{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:8px;padding:8px 10px;background:#ffffffb3;border-radius:12px}.suggestion-label{font-weight:600;font-size:12px;color:var(--ink)}.suggestion-swatch{width:36px;height:28px;border-radius:10px;border:1px solid rgba(0,0,0,.08)}.suggestion-only{border:1px dashed rgba(15,107,255,.35);background:#ffffffb3}@media (max-width: 1100px){.palette-columns,.palette-row{grid-template-columns:1fr}}.palette-card.selected{border:1px solid rgba(15,107,255,.45);box-shadow:0 16px 30px #0f6bff33}.palette-header-top{display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap}.summary-palette{display:flex;flex-direction:column;gap:14px}.summary-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.summary-groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.summary-group{background:#ffffffbf;border:1px solid rgba(15,25,40,.08);border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:8px}.summary-group-header{display:flex;align-items:center;gap:8px}.summary-group-title{font-weight:600;font-size:13px;color:var(--ink)}.summary-group-input{flex:1}.summary-group-actions{margin-left:auto}.summary-items{display:flex;flex-direction:column;gap:8px;min-height:40px}.summary-item{border:1px solid rgba(15,25,40,.08);border-radius:12px;padding:8px;background:#ffffffe6;display:flex;flex-direction:column;gap:6px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;cursor:grab}.summary-group-default{padding:10px}.summary-group-default .summary-group-header{margin-bottom:6px}.summary-group-default .summary-group-title{font-size:13px}.summary-group-default .summary-items{gap:6px}.summary-group-default .summary-item{padding:6px}.summary-group-default .summary-item-title{font-size:11px}.summary-item.locked{opacity:.75;cursor:default}.summary-item.dragging{opacity:.35;cursor:grabbing}.summary-item.drop-target{border-color:#0f6bff73;box-shadow:0 8px 16px #0f6bff1f}.summary-item-header{display:grid;grid-template-columns:104px 1fr auto;gap:8px;align-items:center}.summary-item-title{font-size:12px;color:var(--ink)}.summary-item-hex{font-size:12px;color:var(--ink-soft);font-weight:600;letter-spacing:.02em}.summary-item .summary-swatch{width:96px;height:48px;border-radius:12px}.summary-item.drop-target.before{border-top:2px solid rgba(15,107,255,.45)}.summary-item.drop-target.after{border-bottom:2px solid rgba(15,107,255,.45)}.summary-item .swatch-mini{width:96px;height:48px;border-radius:12px}.summary-item.placeholder{border:2px dashed rgba(15,107,255,.35);background:#0f6bff0f;min-height:78px;box-shadow:none}.summary-item-actions{display:inline-flex;align-items:center;gap:6px}.summary-item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.summary-role-toggle{gap:6px}.summary-role-chip{width:24px;height:24px;padding:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center}.summary-role-select{padding:4px 6px;font-size:12px}.lab-section{display:flex;flex-direction:column;gap:16px}.lab-panel{display:flex;flex-direction:column;gap:16px;padding:14px;overflow:hidden}.lab-mode-tabs{display:inline-flex;gap:8px;flex-wrap:wrap}.lab-mix-panel{display:flex;flex-direction:column;gap:14px}.lab-mix-rows{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:10px}.lab-mix-row{display:flex;flex-direction:column;gap:8px;align-items:stretch;padding:8px;border:1px solid var(--line);border-radius:12px;background:#ffffffbf}.lab-mix-row.active{border-color:#0f6bff73;box-shadow:0 0 0 1px #0f6bff33}.lab-mix-add-tile{border:1px dashed rgba(15,107,255,.45);border-radius:12px;background:#0f6bff0a;color:#0f6bff;font-size:38px;line-height:1;min-height:260px;cursor:pointer}.lab-mix-slot-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.lab-mix-slot-actions{display:inline-flex;align-items:center;gap:6px}.lab-mix-slot-color{display:flex;align-items:center;gap:8px;min-width:0}.lab-mix-stepper{display:inline-flex;align-items:center;gap:6px}.lab-shortlist{display:flex;flex-direction:column;gap:8px}.lab-shortlist-list{display:flex;flex-wrap:wrap;gap:6px}.lab-warnings{border:1px solid rgba(192,53,70,.25);background:#c035460f;border-radius:10px;padding:8px 10px;display:flex;flex-direction:column;gap:4px}.lab-warning-item{color:#a3303f}.lab-mix-compare{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.lab-recipe-swatches--labeled{gap:10px;align-items:flex-start}.lab-swatch-labeled{display:flex;flex-direction:column;align-items:center;gap:4px}.lab-mix-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px}.lab-mix-kpi{border:1px solid var(--line);background:#ffffffdb;border-radius:10px;padding:8px 10px;display:flex;flex-direction:column;gap:4px}.lab-mix-stage-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.lab-mix-stage-card{border:1px solid var(--line);background:#ffffffdb;border-radius:10px;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.lab-mix-stage-head{display:flex;align-items:center;justify-content:flex-start;gap:8px}.lab-mix-stage-title,.lab-mix-stage-metrics{display:flex;flex-direction:column;gap:2px}.lab-stage-matchbar-wrap{width:100%;height:6px;border-radius:999px;background:#0f19281f;overflow:hidden}.lab-stage-matchbar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#f97316,#f59e0b 35%,#22c55e)}.lab-deltae-callout{border:1px solid rgba(15,107,255,.2);background:#0f6bff0f;border-radius:10px;padding:8px 10px}.lab-palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;max-height:300px;overflow:auto;padding:2px}.lab-palette-card{border:1px solid var(--line);border-radius:10px;background:#ffffffe0;padding:8px;text-align:left;display:flex;flex-direction:column;gap:6px;cursor:pointer}.lab-palette-card.pinned{border-color:#0f6bff59}.lab-palette-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.lab-palette-title{font-size:13px;font-weight:600;color:var(--ink)}.lab-mix-bar{height:12px;border-radius:999px;overflow:hidden;border:1px solid rgba(15,25,40,.12);background:#ffffffe6;display:flex}.lab-mix-bar-segment{height:100%}.lab-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;align-items:end}.lab-hex-flow{display:grid;gap:10px}.lab-flow-card{border:1px solid var(--line);border-radius:14px;background:#ffffffc7;padding:10px;display:flex;flex-direction:column;gap:10px}.lab-flow-title{font-size:13px;font-weight:700;color:var(--ink)}.lab-inputs--hex-step{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.lab-flow-target{display:flex;align-items:center;gap:10px}.lab-multi-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid rgba(15,25,40,.12);border-radius:12px;background:#fff;padding:8px 12px;font-size:13px;cursor:pointer}.lab-multi-caret{font-size:12px;opacity:.7}.lab-multi-menu{position:absolute;margin-top:6px;background:#fff;border:1px solid rgba(15,25,40,.12);border-radius:12px;box-shadow:var(--shadow-soft);padding:6px;display:flex;flex-direction:column;gap:4px;min-width:200px;max-height:220px;overflow:auto;z-index:20}.lab-multi-option{display:flex;align-items:center;justify-content:space-between;border:1px solid transparent;border-radius:10px;padding:6px 10px;background:#ffffffe6;cursor:pointer;font-size:13px}.lab-multi-option.active{border-color:#0f6bff4d;background:#0f6bff14}.lab-multi-check{color:#0f6bff;font-weight:700}.lab-multi-empty{padding:6px 10px;font-size:12px;color:var(--ink-soft)}.input-stack{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--ink-soft)}.lab-inputs .input-stack{position:relative}.lab-swatch{width:54px;height:54px;border-radius:12px;border:1px solid rgba(15,25,40,.1);box-shadow:inset 0 1px #ffffff80}.lab-swatch.small{width:36px;height:36px;border-radius:10px}.lab-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.lab-actions--hex{border:1px solid var(--line);border-radius:14px;background:#ffffffc7;padding:12px}.lab-run-btn{min-width:200px;font-weight:700}.lab-error{color:#c03546}.lab-note{color:#51606e}.lab-results{display:flex;flex-direction:column;gap:12px}.lab-results--sticky{position:sticky;bottom:8px;z-index:8}.lab-results-stack{display:flex;flex-direction:column;gap:12px}.lab-results-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.lab-results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:16px;align-items:start}.lab-results-grid--spoiler{margin-top:10px}.lab-spoiler{border:1px solid rgba(15,25,40,.12);border-radius:12px;padding:8px 10px;background:#ffffffa6;overflow:hidden}.lab-spoiler summary{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13px;color:var(--ink-soft);list-style:none;display:inline-flex;align-items:center;gap:8px}.lab-spoiler summary::-webkit-details-marker{display:none}.lab-spoiler summary:before{content:"▸";font-size:11px;transition:transform .15s ease}.lab-spoiler[open] summary:before{transform:rotate(90deg)}.lab-spoiler[open] summary{margin-bottom:10px}.lab-recipe{background:#ffffffe6;border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:10px;overflow:hidden}.lab-recipe--hex{gap:12px}.lab-recipe-top{display:grid;grid-template-columns:1fr auto auto;align-items:start;gap:10px}.lab-recipe-top-main{min-width:0}.lab-recipe-scorebox{border:1px solid rgba(15,107,255,.24);border-radius:12px;background:linear-gradient(180deg,#0f6bff17,#0f6bff08);padding:8px 10px;text-align:center;min-width:86px}.lab-recipe-score{font-size:24px;line-height:1;font-weight:800;color:#0f6bff}.lab-recipe-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.lab-recipe-header>div:first-child{min-width:0}.lab-recipe-actions{display:inline-flex;align-items:center;gap:6px;margin-left:auto;flex-shrink:0}.lab-recipe-title{font-weight:600}.lab-recipe-metrics{font-size:12px;color:var(--ink-soft)}.lab-recipe-name-input{width:100%;flex:1;min-width:160px}.lab-recipe-swatches{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}.lab-recipe .lab-swatch-labeled{align-items:flex-start;min-width:58px}.lab-recipe .lab-swatch-labeled .card-sub{font-size:11px;line-height:1.2}.lab-recipe-hints{display:flex;flex-wrap:wrap;gap:6px}.lab-chip{display:inline-flex;align-items:center;border:1px solid rgba(15,25,40,.12);border-radius:999px;padding:3px 8px;font-size:12px;color:var(--ink-soft);background:#ffffffe0}.lab-recipe-items{display:flex;flex-direction:column;gap:8px;border-top:1px solid rgba(15,25,40,.08);padding-top:8px}.lab-recipe-item{display:grid;grid-template-columns:40px 1fr;gap:10px;align-items:center}.lab-recipe-edit{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.lab-input-mini{width:70px;padding:6px 8px}.lab-recipe-name{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}.lab-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;font-size:12px;background:#0f6bff1a}.lab-badge.ok{background:#1c965a1f}.lab-badge.plan{background:#ffae3c2e}.lab-loading{display:inline-flex;align-items:center;gap:8px;margin-top:6px;color:#6b7280;font-size:13px}@media (max-width: 980px){.lab-recipe-top{grid-template-columns:1fr auto}}.lab-spinner{width:16px;height:16px;border-radius:50%;border:2px solid rgba(107,114,128,.25);border-top-color:#6b7280cc;animation:lab-spin .9s linear infinite}@keyframes lab-spin{to{transform:rotate(360deg)}}.selected-badge{align-self:flex-start;background:#0f6bff1f;color:#0f6bff;font-size:11px;padding:4px 8px;border-radius:999px;margin-bottom:8px}.picker-preview{display:flex;align-items:center;gap:16px;padding:14px 16px;border-radius:var(--radius-lg);background:linear-gradient(180deg,#fffffff5,#f7fbffed);border:1px solid var(--line);box-shadow:0 12px 24px #0a16281a}.preview-swatch{width:60px;height:60px;border-radius:16px;border:1px solid rgba(15,25,40,.1)}.preview-canvas{width:180px;height:180px;border-radius:12px;border:1px solid rgba(15,25,40,.1);image-rendering:pixelated}.badge{background:#fffc;padding:4px 10px;border-radius:999px;font-size:11px;color:var(--ink-soft);box-shadow:inset 0 1px #ffffffe6}.version-badge{position:fixed;right:16px;bottom:14px;font-size:12px;color:#141e3299;background:#ffffffb3;padding:6px 10px;border-radius:999px;box-shadow:var(--shadow-soft);pointer-events:none;z-index:30}.badge.active{background:#0f6bff1f;color:#0f6bff}.card-actions{display:flex;gap:8px;margin-top:auto}.card-actions button{flex:1;border-radius:10px;border:none;background:var(--muted);padding:8px;cursor:pointer;font-size:12px}.filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--line);background:#ffffffd1;box-shadow:0 6px 14px #0a16280f}.section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:14px 16px;border-radius:var(--radius-lg);border:1px solid var(--line);background:#ffffffd6;box-shadow:0 10px 20px #0a162814}.section-actions{display:flex;flex-wrap:wrap;gap:10px}.tab-switch{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.my-library .section-header{margin-bottom:16px}.my-library .section-actions{margin-top:6px}.my-library .filters{margin-top:14px}.my-library .image-swatch{display:none}.my-library .swatch-pair{grid-template-columns:1fr}.inventory-price{display:inline-flex;align-items:center;gap:8px;margin-top:10px;margin-bottom:6px;font-size:12px;color:#202834b3}.inventory-price-label{font-weight:600;color:#202834e6}.inventory-price-button{border:1px solid rgba(15,25,40,.12);background:#fffffff5;border-radius:999px;padding:4px 10px;font-size:12px;color:#0f1928d9;transition:border-color .2s ease,box-shadow .2s ease}.inventory-price-button:hover{border-color:#3b82f64d;box-shadow:0 8px 18px #2563eb1f}.inventory-price-input{width:88px;font-size:12px;padding:4px 10px;border-radius:999px;border:1px solid rgba(59,130,246,.35);background:#fffffffa;color:#0f1928e6}.input{background:#fffffff0;border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 11px;font-size:13px;box-shadow:inset 0 1px #ffffffe6;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.input:focus{outline:none;border-color:#1365f173;box-shadow:0 0 0 3px #1365f124,inset 0 1px #ffffffe6}.file-input{cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e1473;display:flex;align-items:center;justify-content:center;padding:30px;z-index:20}.editor-modal{background:linear-gradient(180deg,#fffffffa,#f5f8fff2);border-radius:22px;padding:18px;width:min(1000px,95vw);max-height:90vh;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.8)}.editor-header{display:flex;justify-content:flex-end}.editor-toolbar{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}.editor-actions{display:flex;flex-wrap:wrap;gap:8px}.editor-actions .ghost-btn.active{border-color:#0f6bff99;box-shadow:0 0 0 2px #0f6bff26}.sample-marker{position:absolute;width:16px;height:16px;margin-left:-8px;margin-top:-8px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 2px #0f6bffbf;pointer-events:none}.sample-marker:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:#0f6bffb3}.editor-canvas-wrap{position:relative;background:#ffffffd9;border-radius:18px;padding:12px;display:flex;align-items:center;justify-content:center;min-height:360px;overflow:hidden}.editor-canvas-wrap canvas{max-width:100%;max-height:70vh;border-radius:12px;background:transparent;box-shadow:var(--shadow-soft)}.editor-canvas-wrap.crop-mode{cursor:crosshair}.crop-rect{position:absolute;border:2px dashed rgba(15,107,255,.8);background:#0f6bff2e;pointer-events:none}.editor-hint{font-size:13px;color:#141e32a6}.wheel-layout{display:grid;gap:18px}.wheel-panel{background:var(--glass);border-radius:24px;padding:20px;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.6)}.wheel-controls{display:grid;grid-template-columns:minmax(240px,1fr) minmax(260px,1fr);gap:18px;margin-top:16px}.wheel-picker{display:grid;gap:14px;justify-items:center}.wheel-canvas-wrap{position:relative;width:320px;height:320px}.wheel-canvas{width:320px;height:320px;border-radius:50%;cursor:crosshair;box-shadow:var(--shadow-soft)}.wheel-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.wheel-links line{stroke:#0f6bff8c;stroke-width:2}.wheel-polygon{fill:#0f6bff1f;stroke:#0f6bff99;stroke-width:2}.wheel-marker{position:absolute;width:14px;height:14px;border-radius:50%;border:2px solid white;transform:translate(-50%,-50%);box-shadow:0 4px 12px #0000004d;pointer-events:none}.wheel-marker.primary{border-color:#141e32e6;box-shadow:0 0 0 3px #ffffffd9,0 4px 12px #00000059}.wheel-base{display:flex;gap:10px;align-items:center}.wheel-settings{display:grid;gap:12px}.wheel-schemes{display:flex;flex-wrap:wrap;gap:8px}.range-row{display:grid;gap:6px;font-size:13px}.range-row.toggle-row{grid-template-columns:1fr auto;align-items:center}.wheel-swatches{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}.wheel-swatches.compact{gap:6px;margin-top:6px}.wheel-swatch-card{display:flex;align-items:center;gap:8px;background:#ffffffb8;padding:8px 12px;border-radius:999px;border:1px solid rgba(15,25,40,.1)}.mini-swatch{width:22px;height:22px;border-radius:8px;box-shadow:inset 0 0 0 1px #fff9}.wheel-matches{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:12px}.wheel-match-title{display:flex;align-items:center;gap:10px;font-weight:600;margin-bottom:10px}.wheel-match-item{display:flex;gap:10px;align-items:center;background:#ffffffbf;border-radius:14px;padding:8px 10px;border:1px solid rgba(15,25,40,.08);margin-bottom:8px}.wheel-match-column .muted{margin-top:6px}.modal{background:linear-gradient(180deg,#fffffffa,#f5f8fff2);border-radius:22px;padding:24px;max-width:720px;width:100%;box-shadow:var(--shadow);max-height:85vh;overflow:auto;border:1px solid rgba(255,255,255,.8)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.modal h3{font-size:24px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.bulk-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;padding:12px;margin:12px 0;background:#ffffffe6;border-radius:14px;box-shadow:var(--shadow-soft)}.bulk-title{font-size:13px;color:var(--ink-soft);align-self:center}.table{width:100%;border-collapse:separate;border-spacing:0;background:#fffffff0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft)}.table-wrap{max-height:50vh;overflow:auto;margin-top:12px}.table th,.table td{padding:10px 12px;font-size:13px;border-bottom:1px solid rgba(15,25,40,.08)}.swatch-mini-pair{display:grid;grid-template-columns:18px 18px;gap:6px}.swatch-mini-pair.single{grid-template-columns:18px}.swatch-mini{width:18px;height:18px;border-radius:6px;border:1px solid rgba(15,25,40,.1);overflow:hidden;position:relative}.swatch-mini--contrast:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#ffffffa6,#fff3 28%,#0000,#00000080 72%,#000000b8);mix-blend-mode:soft-light;pointer-events:none}.swatch-mini--metallic:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 35% 30%,#ffffffb3,#fff0 42%),linear-gradient(115deg,#fff6,#fff0,#0003 70%,#00000057),linear-gradient(90deg,#ffffff1f,#fff0 48%,#00000038),radial-gradient(circle at 78% 80%,#00000047,#0000 55%);mix-blend-mode:soft-light;pointer-events:none}.swatch-mini--wash:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffff0f,#00000061 58%,#000000eb),radial-gradient(circle at 70% 25%,#ffffff1a,#fff0 55%);mix-blend-mode:soft-light;pointer-events:none}.swatch--fx:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 18% 22%,#ffffff8c,#fff0 28%),radial-gradient(circle at 78% 28%,#0000008c,#0000 32%),radial-gradient(circle at 70% 72%,#000000a6,#0000 36%),radial-gradient(circle at 38% 68%,#ffffff59,#fff0 30%),radial-gradient(circle at 52% 48%,#00000040,#0000 22%),radial-gradient(circle at 28% 52%,#ffffff38,#fff0 20%),radial-gradient(circle at 82% 58%,#fff3,#fff0 18%),radial-gradient(circle at 58% 30%,#0000004d,#0000 18%);mix-blend-mode:overlay;pointer-events:none}.swatch-mini--fx:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 30%,#ffffff80,#fff0 30%),radial-gradient(circle at 75% 40%,#00000080,#0000 32%),radial-gradient(circle at 60% 80%,#0009,#0000 34%),radial-gradient(circle at 40% 60%,#ffffff4d,#fff0 22%),radial-gradient(circle at 58% 28%,#00000047,#0000 20%);mix-blend-mode:overlay;pointer-events:none}.image-swatch-mini img{width:100%;height:100%;object-fit:cover;border-radius:4px}.table th{text-align:left;color:var(--ink-soft);font-weight:600;background:linear-gradient(180deg,#f8fbff,#f1f6ff);position:sticky;top:0;z-index:1}.empty-state{padding:40px;background:linear-gradient(180deg,#fffffff2,#f5faffe6);border:1px dashed rgba(19,101,241,.24);border-radius:22px;text-align:center;color:var(--ink-soft);box-shadow:var(--shadow-soft)}@media (max-width: 960px){.app-shell{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:1px solid rgba(15,25,40,.05)}.main{padding:24px}.top-bar{flex-direction:column;align-items:flex-start;gap:14px}}.side-block .card-grid.compact-grid{grid-template-columns:1fr}.side-block .paint-card{padding:14px}:root{--bg: #f5f6f8;--bg-elev: #ffffff;--ink: #111827;--ink-soft: #5f6b7a;--ink-faint: #8c97a8;--accent: #0a66ff;--accent-2: #0fbf99;--muted: #eceff4;--radius-xl: 18px;--radius-lg: 14px;--radius-md: 10px;--radius-sm: 8px;--line: rgba(17, 24, 39, .1);--shadow: 0 12px 30px rgba(17, 24, 39, .12);--shadow-soft: 0 4px 16px rgba(17, 24, 39, .08)}body{font-family:SF Pro Text,Segoe UI,Roboto,Noto Sans,Helvetica Neue,Arial,sans-serif;background:linear-gradient(180deg,#fafbfc,#f3f5f8);color:var(--ink)}h1,h2,h3{font-family:SF Pro Display,SF Pro Text,Segoe UI,Roboto,Noto Sans,Helvetica Neue,Arial,sans-serif;letter-spacing:-.015em;font-weight:700}.sidebar{background:linear-gradient(180deg,#f8fafc,#f3f5f9);color:var(--ink);border-right:1px solid rgba(17,24,39,.08);box-shadow:none}.sidebar-total,.sidebar .pill{background:#ffffffe6;color:var(--ink-soft);border:1px solid var(--line)}.sidebar-account{background:#ffffffeb;border:1px solid var(--line)}.account-name{color:var(--ink)}.account-sub{color:var(--ink-soft)}.sidebar .ghost-btn{background:#ffffffe6;color:var(--ink);border:1px solid var(--line)}.sidebar .ghost-btn.active{background:#0a66ff1a;border-color:#0a66ff66;color:#0750c8}.main{padding:28px 34px 56px}.community-banner{border-radius:12px;padding:10px 14px;background:#fffffff0;border:1px solid var(--line);box-shadow:none}.top-bar{margin-bottom:14px;padding:16px;border-radius:var(--radius-lg);border:1px solid var(--line);background:#fffffff5;box-shadow:none}.top-bar h2{font-size:40px;margin:0}.card-sub{color:var(--ink-soft)}.filters{padding:12px;border-radius:var(--radius-lg);background:#ffffffeb;border:1px solid var(--line);box-shadow:none;margin-bottom:14px}.primary-btn,.ghost-btn,.toggle-chip,.role-chip{border-radius:10px;font-weight:600}.primary-btn{background:linear-gradient(180deg,#1d76ff,#0a66ff);border:1px solid rgba(10,102,255,.35);box-shadow:0 6px 14px #0a66ff38}.ghost-btn{background:#ffffffeb;border:1px solid var(--line);box-shadow:none}.ghost-btn:hover{border-color:#0a66ff59}.input{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:none;font-size:13px;padding:9px 11px}.input:focus{border-color:#0a66ff73;box-shadow:0 0 0 3px #0a66ff1f}.card-grid{gap:14px}.paint-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px;box-shadow:none}.paint-card:before{display:none}.paint-card:hover{transform:translateY(-1px);box-shadow:0 10px 20px #1118271a}.painting-list,.palette-block,.point-panel,.painting-toolbar,.painting-canvas,.picker-preview,.section-header,.execution-panel,.settings-card,.lab-panel{background:#fffffff2;border:1px solid var(--line);box-shadow:none;border-radius:var(--radius-lg)}.planning-image-panel{border-radius:12px;background:#fffffff5;border:1px solid var(--line)}.panel-label{text-transform:none;letter-spacing:0;font-size:12px;color:var(--ink-soft);background:transparent;border:0;padding:0}.painting-image-wrap{border:1px solid rgba(17,24,39,.12);box-shadow:none}.table{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:none}.table th{background:#f7f9fc;color:#556074}body,button,input,select,textarea{font-family:Manrope,Segoe UI,Roboto,Noto Sans,Helvetica Neue,Arial,sans-serif;font-weight:400}h1,h2,h3,.sidebar h1,.top-bar h2,.card-title,.card-title-line,.paint-card .card-title-line,.account-name,.primary-btn,.ghost-btn,.toggle-chip,.role-chip{font-family:Manrope,Segoe UI,Roboto,Noto Sans,Helvetica Neue,Arial,sans-serif}h1,h2,h3{font-weight:600;letter-spacing:-.012em}.sidebar h1,.top-bar h2{font-weight:600}.card-title,.card-title-line,.paint-card .card-title-line,.account-name,.primary-btn,.ghost-btn,.toggle-chip,.role-chip{font-weight:500}.library-filters-wrap{display:grid;gap:10px;margin-bottom:14px}.filters.filters-primary{grid-template-columns:minmax(240px,1.6fr) repeat(4,minmax(170px,1fr)) auto;align-items:center}.sticky-filters{position:sticky;top:12px;z-index:12;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.filters-more-btn{white-space:nowrap;min-height:38px}.my-library-view-switch{display:inline-flex;gap:8px;flex-wrap:wrap}.my-library-view-switch .ghost-btn{min-height:40px;padding:8px 16px;font-size:14px}.filters.filters-chart-controls{grid-template-columns:repeat(3,minmax(220px,1fr));margin-bottom:0}.filters.filters-advanced{grid-template-columns:repeat(4,minmax(170px,1fr));margin-bottom:0;animation:filters-fade-in .18s ease}.active-filters-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-lg);background:#ffffffeb}.active-filters-label{font-size:12px;color:var(--ink-soft);white-space:nowrap}.active-filters-list{display:flex;flex-wrap:wrap;gap:8px;flex:1}.active-filters-empty{font-size:12px;color:var(--ink-faint)}.filter-chip{border:1px solid rgba(10,102,255,.24);background:#0a66ff14;color:#0a57d0;border-radius:999px;font-size:12px;padding:6px 10px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.filter-chip:hover{background:#0a66ff21;border-color:#0a66ff59}.filter-chip-close{font-size:14px;line-height:1}.filters-reset-btn{min-height:34px;white-space:nowrap}@keyframes filters-fade-in{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1260px){.filters.filters-primary{grid-template-columns:repeat(3,minmax(170px,1fr))}}@media (max-width: 920px){.filters.filters-primary,.filters.filters-advanced,.filters.filters-chart-controls{grid-template-columns:repeat(2,minmax(150px,1fr))}.sticky-filters{top:8px}}@media (max-width: 640px){.lab-panel{padding:10px}.lab-inputs,.lab-mix-rows{grid-template-columns:1fr}.lab-results--sticky{position:static}.lab-actions{align-items:stretch}.lab-actions .ghost-btn{width:100%}.lab-mix-stage-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.filters.filters-primary,.filters.filters-advanced,.filters.filters-chart-controls{grid-template-columns:1fr}.my-library-view-switch{width:100%}.my-library-view-switch .ghost-btn{flex:1}.active-filters-row{align-items:flex-start}}.my-library-chart{display:grid;gap:12px}.my-library-chart-group{border:1px solid var(--line);border-radius:10px;background:#fffffffa;padding:8px}:root[data-theme=dark]{--bg: #0b111a;--bg-elev: #111a28;--ink: #e6edf8;--ink-soft: #9aa8bf;--ink-faint: #74839d;--accent: #58a6ff;--accent-2: #26c8a4;--muted: #1d2a3f;--line: rgba(148, 163, 184, .24);--shadow: 0 16px 34px rgba(2, 8, 18, .55);--shadow-soft: 0 8px 24px rgba(2, 8, 18, .42)}[data-theme=dark] body{background:radial-gradient(900px 420px at -5% 0%,rgba(56,139,253,.22),transparent 60%),radial-gradient(700px 420px at 100% 0%,rgba(38,200,164,.16),transparent 62%),linear-gradient(180deg,#0b111a,#0f1724);color:var(--ink)}[data-theme=dark] .sidebar{background:linear-gradient(180deg,#0f1725,#101a2c);color:var(--ink);border-right:1px solid rgba(148,163,184,.2);box-shadow:6px 0 26px #02081459}[data-theme=dark] .sidebar-total,[data-theme=dark] .sidebar .pill,[data-theme=dark] .sidebar-account{background:#141f31d9;color:var(--ink-soft);border-color:#94a3b833}[data-theme=dark] .account-name{color:var(--ink)}[data-theme=dark] .account-sub{color:var(--ink-soft)}[data-theme=dark] .sidebar .ghost-btn{background:#141f31e0;color:var(--ink);border-color:#94a3b83d}[data-theme=dark] .sidebar .ghost-btn.active{background:#58a6ff2b;border-color:#58a6ff6b;color:#a9d2ff}[data-theme=dark] .community-banner,[data-theme=dark] .top-bar,[data-theme=dark] .filters,[data-theme=dark] .active-filters-row,[data-theme=dark] .settings-card,[data-theme=dark] .section-header,[data-theme=dark] .painting-list,[data-theme=dark] .palette-block,[data-theme=dark] .point-panel,[data-theme=dark] .painting-toolbar,[data-theme=dark] .painting-canvas,[data-theme=dark] .picker-preview,[data-theme=dark] .execution-panel,[data-theme=dark] .lab-panel,[data-theme=dark] .lab-flow-card,[data-theme=dark] .lab-actions--hex,[data-theme=dark] .lab-recipe,[data-theme=dark] .lab-mix-row,[data-theme=dark] .lab-mix-stage-card,[data-theme=dark] .admin-users-table-wrap,[data-theme=dark] .bulk-actions,[data-theme=dark] .suggestion-card,[data-theme=dark] .summary-group,[data-theme=dark] .summary-item,[data-theme=dark] .table,[data-theme=dark] .wheel-panel{background:#111a28e0;border-color:#94a3b833;box-shadow:var(--shadow-soft)}[data-theme=dark] .top-bar{background:radial-gradient(520px 220px at 8% -5%,rgba(88,166,255,.14),transparent 62%),linear-gradient(180deg,#111a28f2,#101826eb)}[data-theme=dark] .filters,[data-theme=dark] .active-filters-row{background:#111a28e6}[data-theme=dark] .paint-card,[data-theme=dark] .photo-card,[data-theme=dark] .reference-card,[data-theme=dark] .planning-image-panel,[data-theme=dark] .execution-item,[data-theme=dark] .painting-item,[data-theme=dark] .legend-item,[data-theme=dark] .wheel-match-item,[data-theme=dark] .analog-item{background:#121d2eeb;border-color:#94a3b833;color:var(--ink)}[data-theme=dark] .paint-card:before{background:linear-gradient(135deg,rgba(255,255,255,.06),transparent 60%)}[data-theme=dark] .paint-card:hover{box-shadow:0 14px 28px #02081273}[data-theme=dark] .ghost-btn,[data-theme=dark] .toggle-chip,[data-theme=dark] .role-chip,[data-theme=dark] .icon-btn,[data-theme=dark] .session-actions .icon-btn,[data-theme=dark] .card-remove{background:#172336eb;color:var(--ink);border-color:#94a3b83d}[data-theme=dark] .ghost-btn:hover,[data-theme=dark] .toggle-chip.active{border-color:#58a6ff75}[data-theme=dark] .toggle-chip.active,[data-theme=dark] .role-chip.active,[data-theme=dark] .badge.active,[data-theme=dark] .point-badge,[data-theme=dark] .reference-badge{background:#58a6ff33;color:#a9d2ff}[data-theme=dark] .input,[data-theme=dark] .inventory-price-input,[data-theme=dark] .lab-multi-toggle,[data-theme=dark] .recent-chip,[data-theme=dark] .paint-search-item{background:#141f31f5;color:var(--ink);border-color:#94a3b83d;box-shadow:none}[data-theme=dark] .input:focus{border-color:#58a6ff80;box-shadow:0 0 0 3px #58a6ff33}[data-theme=dark] .table th{background:#15243a;color:var(--ink-soft)}[data-theme=dark] .table td,[data-theme=dark] .table th,[data-theme=dark] .admin-users-table th,[data-theme=dark] .admin-users-table td{border-bottom-color:#94a3b82e}[data-theme=dark] .admin-users-table tbody tr:hover{background:#22355073}[data-theme=dark] .admin-users-table .row-blocked{background:#812b2b52}[data-theme=dark] .modal,[data-theme=dark] .editor-modal,[data-theme=dark] .gallery-modal{background:linear-gradient(180deg,#111a28fa,#0f1723f5);border-color:#94a3b838}[data-theme=dark] .modal-backdrop{background:#020812b8}[data-theme=dark] .gallery-frame{background:#101a29}[data-theme=dark] .version-badge{color:#dae5f5bf;background:#0f1723c7}[data-theme=dark] .empty-state{background:#111a28db;border-color:#58a6ff59;color:var(--ink-soft)}[data-theme=dark] .filter-chip{background:#58a6ff29;border-color:#58a6ff5c;color:#a9d2ff}[data-theme=dark] .panel-label{color:var(--ink-soft)}[data-theme=dark] .help-tip{background:#172336f2;border-color:#94a3b83d;color:var(--ink-soft)}.my-library-chart-group.no-heading{border:0;padding:0;background:transparent}.my-library-chart-group-title{font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;padding-left:2px}.my-library-chart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:6px}.my-library-chart-item{border:1px solid var(--line);border-radius:6px;background:#fff;overflow:hidden}.my-library-chart-swatch{position:relative;height:50px;display:flex;align-items:flex-end;padding:4px 6px}.my-library-chart-hex{position:relative;z-index:1;font-size:10px;line-height:1;color:#ffffffeb;background:#14141447;border-radius:999px;padding:3px 6px}.my-library-chart-dot{position:absolute;z-index:2;right:7px;top:6px;width:11px;height:11px;border-radius:999px;border:1px solid rgba(255,255,255,.8);box-shadow:0 0 0 2px #0f14232e}.my-library-chart-dot.owned{background:#ff4242}.my-library-chart-dot.planned{background:#ffd53d}.my-library-chart-meta{padding:5px 6px 6px;display:grid;gap:1px}.my-library-chart-code{font-size:11px;color:var(--ink-soft)}.my-library-chart-name{font-size:12px;color:var(--ink);font-weight:500;line-height:1.2}.my-library-chart-brand{font-size:11px;color:var(--ink-faint);line-height:1.2}.library-chart{display:grid;gap:12px}.library-chart-group{border:1px solid var(--line);border-radius:10px;background:#fffffffa;padding:8px}.library-chart-group.no-heading{border:0;padding:0;background:transparent}.library-chart-group-title{font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;padding-left:2px}.library-chart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(112px,1fr));gap:6px}.library-chart-item{border:1px solid var(--line);border-radius:6px;background:#fff;overflow:hidden}.library-chart-swatch{position:relative;height:52px;display:flex;align-items:flex-end;padding:5px 6px}.library-chart-swatch span{position:relative;z-index:1;font-size:10px;line-height:1;color:#fffffff0;background:#14141447;border-radius:999px;padding:3px 6px}.library-chart-meta{padding:5px 6px 6px;display:grid;gap:1px}.library-chart-code{font-size:11px;color:var(--ink-soft)}.library-chart-name{font-size:12px;color:var(--ink);font-weight:500;line-height:1.2}.library-chart-brand{font-size:11px;color:var(--ink-faint);line-height:1.2}.chart-load-sentinel-wrap{display:grid;justify-items:center;gap:6px;padding:8px 0 2px}.chart-load-sentinel{width:100%;height:1px}
