:root{--crimson:#A01020;--crimson-dark:#7A0018;--crimson-light:#C8182E;--crimson-pale:#FAE8EB;--mahogany:#1C0806;--cream:#F5EFE6;--bg:#F5F0E8;--surface:#FFFFFF;--ink:#1A1612;--ink-80:rgba(26,22,18,.8);--ink-60:rgba(26,22,18,.6);--ink-40:rgba(26,22,18,.4);--ink-30:rgba(26,22,18,.3);--ink-15:rgba(26,22,18,.15);--ink-10:rgba(26,22,18,.1);--ink-05:rgba(26,22,18,.05);--green:#27AE60;--green-pale:#EAF7EE;--amber:#A86828;--amber-pale:#FDF3E3;--blue:#2C5F8A;--blue-pale:#EAF0F7;--font:system-ui,-apple-system,"Segoe UI",sans-serif;--font-serif:Georgia,"Times New Roman",serif;--font-mono:"SF Mono","Fira Code","Courier New",monospace;--space-xs:4px;--space-sm:8px;--space-md:14px;--space-lg:20px;--space-xl:32px;--radius-sm:6px;--radius:10px;--radius-lg:16px;--radius-xl:24px;--radius-pill:999px;--shadow-sm:0 1px 4px rgba(0,0,0,.08);--shadow:0 2px 12px rgba(0,0,0,.1);--shadow-lg:0 6px 28px rgba(0,0,0,.14);--shadow-up:0 -4px 20px rgba(0,0,0,.1);--header-h:52px;--tabbar-h:48px;--toolbar-h:44px;--nav-h:68px;--bar-bottom-h:68px;--rail-w:188px;--content-top:calc(var(--header-h) + var(--tabbar-h));--max-w:960px;--side-pad:18px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-text-size-adjust:100%;background:#f5f0e8;overflow-x:hidden}body{font-family:var(--font);font-size:14px;line-height:1.5;color:var(--ink);background:var(--bg);min-height:100%;overscroll-behavior-x:none;overscroll-behavior-y:auto;overflow-x:hidden}button{font-family:var(--font);cursor:pointer}input,select,textarea{font-family:var(--font)}a{color:var(--crimson);text-decoration:none}img{max-width:100%;display:block}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--mahogany);display:flex;align-items:center;padding:0 var(--side-pad);z-index:500;box-shadow:0 2px 12px #00000059;overflow:hidden}.wordmark{font-family:var(--font-serif);font-size:22px;line-height:1;display:flex;align-items:baseline;flex-shrink:0}.wordmark-sfumato{font-weight:400;color:var(--cream);letter-spacing:.03em}.wordmark-art{font-weight:700;color:var(--crimson-light);letter-spacing:.03em}.header-tagline{font-size:10px;font-style:italic;color:#ffffff61;margin-left:10px;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.header-right{margin-left:auto;display:flex;align-items:center;gap:8px;flex-shrink:0}.app-clock{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;color:#ffffffc7;background:#00000038;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-pill);padding:3px 10px;white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:default;text-transform:uppercase}.ai-pill{display:flex;align-items:center;gap:4px;background:#27ae6026;border:1px solid rgba(39,174,96,.35);border-radius:var(--radius-pill);padding:3px 9px;font-size:10px;font-weight:700;color:#5dbe7a;letter-spacing:.03em}.ai-dot{width:6px;height:6px;border-radius:50%;background:#27ae60;box-shadow:0 0 4px #27ae6099;flex-shrink:0}.version-badge{font-family:var(--font-mono);font-size:11px;color:#ffffff4d;cursor:default}.desktop-tab-bar{position:fixed;top:var(--header-h);left:0;bottom:0;width:var(--rail-w);background:var(--surface);border-right:1px solid var(--ink-10);display:flex;flex-direction:column;align-items:stretch;overflow-y:auto;overflow-x:hidden;z-index:490;box-shadow:var(--shadow-sm);scrollbar-width:thin;-webkit-overflow-scrolling:touch;padding:8px 0}.desktop-tab-bar::-webkit-scrollbar{width:4px}.desktop-tab-bar::-webkit-scrollbar-thumb{background:var(--ink-10);border-radius:2px}.tab-btn{flex-shrink:0;padding:10px 14px 10px 18px;background:none;border:none;border-left:3px solid transparent;font-size:13px;font-weight:600;color:var(--ink-60);white-space:nowrap;cursor:pointer;display:flex;align-items:center;gap:10px;min-height:42px;text-align:left;transition:color .15s,border-color .15s,background .15s}.tab-btn:hover{color:var(--ink);background:var(--ink-05)}.tab-btn.active{color:var(--crimson);border-left-color:var(--crimson);background:var(--crimson-pale);font-weight:700}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:var(--surface);border-top:1px solid var(--ink-10);box-shadow:var(--shadow-up);z-index:490;padding-bottom:env(safe-area-inset-bottom,0px);display:none}.bottom-nav-inner{display:flex;height:100%;align-items:stretch}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;padding:6px 4px 4px;position:relative;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:background .1s}.nav-tab:active{background:var(--ink-05)}.nav-icon{font-size:20px;line-height:1}.nav-label{font-size:10px;font-weight:600;color:var(--ink-40);letter-spacing:.02em}.nav-tab.active .nav-label{color:var(--crimson);font-weight:700}.nav-tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:3px;background:var(--crimson);border-radius:0 0 3px 3px}.nav-more-dots{font-size:18px;font-weight:900;color:var(--ink-40);line-height:1;letter-spacing:.05em}#navMoreBtn.active .nav-more-dots{color:var(--crimson)}#moreBackdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:600;pointer-events:auto}#moreDrawer{display:none;position:fixed;left:0;right:0;bottom:var(--nav-h);z-index:700;background:var(--surface);border-radius:20px 20px 0 0;box-shadow:0 -8px 32px #00000038;padding:12px var(--side-pad) 20px;transform:translateY(100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}#moreDrawer.open{transform:translateY(0)}.drawer-handle{width:40px;height:4px;background:var(--ink-15);border-radius:2px;margin:0 auto 14px}.drawer-title{font-size:11px;font-weight:700;color:var(--ink-40);letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}.drawer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.drawer-btn{display:flex;flex-direction:column;align-items:center;gap:5px;background:var(--bg);border:1.5px solid var(--ink-10);border-radius:var(--radius);padding:12px 4px 10px;cursor:pointer;font-size:10px;font-weight:600;color:var(--ink-80);transition:all .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:60px;justify-content:center}.drawer-btn:active,.drawer-btn.active{background:var(--crimson-pale);border-color:var(--crimson);color:var(--crimson)}.d-icon{font-size:20px}@media(max-width:768px){.bottom-nav{display:block}.desktop-tab-bar{display:none!important}:root{--content-top:var(--header-h)}.main{padding-top:var(--header-h);padding-bottom:calc(var(--nav-h) + 8px)}#stickyColourBar{bottom:var(--nav-h)!important}#stickyBarSpacer{height:calc(var(--bar-bottom-h) + var(--nav-h))!important}body.photo-loaded.matcher-active .main{padding-top:calc(var(--header-h) + var(--toolbar-h))!important}.photo-wrap{height:calc(100svh - var(--header-h) - var(--toolbar-h) - var(--nav-h))!important;max-width:100vw;overflow:hidden}.bottom-nav,.bottom-nav-inner{max-width:100vw;overflow:hidden}}@media(max-width:520px){:root{--side-pad:10px}.app-header{padding:0 var(--side-pad)}.wordmark{font-size:18px}.header-tagline{display:none}.header-right{gap:5px;min-width:0}.app-clock,.ai-pill{font-size:9px;padding:2px 6px}.version-badge{font-size:9px}.beta-badge{display:none!important}}@media(min-width:769px){.bottom-nav{display:none!important}.desktop-tab-bar{display:flex}:root{--content-top:var(--header-h)}.main{padding-top:var(--header-h);padding-left:var(--rail-w)}#stickyColourBar,#photoToolbarFixed{left:var(--rail-w)!important}.photo-wrap{height:calc(100svh - var(--header-h) - var(--toolbar-h))}}.main{min-height:100vh}.tab-content{display:none;min-height:calc(100vh - 100px)}.container{max-width:var(--max-w);margin:0 auto;padding:var(--space-md) var(--side-pad)}.tab-hero{background:linear-gradient(135deg,var(--crimson) 0%,var(--crimson-dark) 100%);padding:14px var(--side-pad) 12px;display:flex;align-items:center;gap:10px}.tab-hero-icon{font-size:22px}.tab-hero-title{font-family:var(--font-serif);font-size:18px;font-weight:400;color:#fff;letter-spacing:.03em}.tab-hero-sub{font-size:11px;color:#fff9;margin-top:2px}.card{background:var(--surface);border:1px solid var(--ink-10);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:12px;box-shadow:var(--shadow-sm)}.card-header{padding:10px var(--space-md);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;display:flex;align-items:center;gap:8px}.card-header.crimson{background:var(--crimson)}.card-header.green{background:var(--green)}.card-header.blue{background:var(--blue)}.card-header.amber{background:var(--amber)}.card-body{padding:var(--space-md)}#recipeCard{overflow:hidden;margin-bottom:10px;display:none;scroll-margin-top:calc(var(--content-top) + var(--toolbar-h) + 8px)}.recipe-swatch{position:relative;height:90px;background:var(--ink-15);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2px;transition:background .3s}.recipe-score{font-family:var(--font-serif);font-size:54px;font-weight:700;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.45);line-height:1;letter-spacing:-.02em}.recipe-score-label{font-size:10px;color:#ffffffb8;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.recipe-hex-tag{position:absolute;bottom:7px;right:12px;font-family:var(--font-mono);font-size:10px;font-weight:700;color:#ffffffd9;display:none;text-shadow:0 1px 3px rgba(0,0,0,.5)}.recipe-bar-wrap{height:8px;border-radius:4px;overflow:hidden;background:var(--ink-05);margin-top:5px}.recipe-bar-fill{height:100%;border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1)}.recipe-ctas{display:flex;gap:8px;padding:0 var(--space-md) var(--space-md)}.match-bar{height:6px;background:var(--ink-10);border-radius:3px;overflow:hidden;margin:6px 0}.match-fill{height:100%;background:linear-gradient(90deg,var(--amber),var(--green));border-radius:3px;transition:width .4s}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius-pill);border:none;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap;touch-action:manipulation}.btn-crimson{background:var(--crimson);color:#fff}.btn-crimson:hover{background:var(--crimson-dark)}.btn-green{background:var(--green);color:#fff}.btn-outline{background:none;border:1.5px solid var(--ink-30);color:var(--ink)}.btn-outline:hover{border-color:var(--ink);background:var(--ink-05)}.btn-sm{padding:6px 12px;font-size:11px}.btn-full{width:100%}.icon-btn{width:36px;height:36px;border-radius:var(--radius);border:1.5px solid var(--ink-15);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all .15s;flex-shrink:0}.icon-btn:hover{border-color:var(--ink-40);background:var(--ink-05)}.icon-btn.active{background:var(--crimson-pale);border-color:var(--crimson)}.form-input{width:100%;padding:10px 12px;border:2px solid var(--ink-30);border-radius:var(--radius);font-size:14px;background:var(--bg);color:var(--ink);margin-bottom:12px;transition:border-color .15s;outline:none}.form-input:focus{border-color:var(--crimson)}.form-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-60);margin-bottom:5px;display:block}.form-select{width:100%;padding:10px 12px;border:2px solid var(--ink-30);border-radius:var(--radius);font-size:14px;background:var(--bg);color:var(--ink);margin-bottom:12px;outline:none;cursor:pointer}.form-select:focus{border-color:var(--crimson)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);font-size:10px;font-weight:700;letter-spacing:.04em}.badge-crimson{background:var(--crimson-pale);color:var(--crimson)}.badge-green{background:var(--green-pale);color:var(--green)}.badge-amber{background:var(--amber-pale);color:var(--amber)}.badge-blue{background:var(--blue-pale);color:var(--blue)}.colour-dot{width:44px;height:44px;border-radius:50%;flex-shrink:0;border:3px solid #fff;box-shadow:0 0 0 1.5px #00000026,var(--shadow);cursor:pointer;transition:transform .15s}.colour-dot:hover{transform:scale(1.12)}.section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-40);padding:10px 0 5px}.empty-state{text-align:center;padding:48px 24px;color:var(--ink-60)}.empty-state-icon{font-size:40px;margin-bottom:12px}.empty-state p{font-size:13px;line-height:1.65}.divider{height:1px;background:var(--ink-10);margin:12px 0}.toast{position:fixed;top:calc(var(--content-top) + 8px);left:50%;transform:translate(-50%) translateY(-10px);background:var(--ink);color:#fff;padding:9px 18px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;white-space:nowrap;max-width:90vw;text-align:center;z-index:900;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:var(--shadow-lg)}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}@media(max-width:768px){.toast{top:calc(var(--header-h) + 8px)}}#stickyColourBar,#stickyBarSpacer{display:none!important}body.matcher-active #stickyColourBar.sticky-has-content{display:flex!important}#stickyBarSpacer.sticky-has-content{display:block!important}#stickyColourBar{position:fixed;bottom:0;left:0;right:0;z-index:400;background:var(--surface);border-top:1.5px solid var(--ink-10);box-shadow:var(--shadow-up);flex-direction:column;padding:8px var(--side-pad) 12px;gap:6px}#photoToolbarFixed{display:none;position:fixed;top:var(--content-top);left:0;right:0;height:var(--toolbar-h);z-index:480;background:var(--surface);border-bottom:1px solid var(--ink-10);box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:0 var(--side-pad);overflow-x:auto;scrollbar-width:none}#photoToolbarFixed::-webkit-scrollbar{display:none}body.photo-loaded.matcher-active #photoToolbarFixed{display:flex}body.photo-loaded.matcher-active .main{padding-top:calc(var(--content-top) + var(--toolbar-h) + 44px)}@media(max-width:768px){body.photo-loaded.matcher-active .main{padding-top:calc(var(--header-h) + var(--toolbar-h) + 44px)!important}body.photo-loaded.matcher-active .photo-wrap{height:calc(100svh - var(--header-h) - var(--toolbar-h) - var(--nav-h) - 44px)!important}}@media(min-width:769px){body.photo-loaded.matcher-active .photo-wrap{height:calc(100svh - var(--content-top) - var(--toolbar-h) - 44px)!important}}.photo-wrap{position:relative;overflow:hidden;cursor:crosshair;background:#111;margin:0 calc(-1 * var(--side-pad));display:flex;align-items:center;justify-content:center}#tab-matcher>#photoArea{margin:0 0 12px!important}#tab-matcher>#photoArea .photo-wrap{margin:0}.sample-photo{width:100%;height:100%;display:block;object-fit:contain;touch-action:pan-y;-webkit-user-select:none;user-select:none}#_pzResetBtn{position:absolute;bottom:8px;right:8px;z-index:12;padding:4px 10px;font-size:10px;font-weight:700;background:#0000008c;color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:20px;cursor:pointer;display:none;font-family:var(--font)}#zoomControls{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;z-index:10}.zoom-btn{width:34px;height:34px;border-radius:50%;background:#ffffffe0;border:none;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:background .15s;line-height:1}.zoom-btn:hover{background:#fff}.sampled-dot{position:absolute;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 1.5px #0000004d,0 2px 8px #0006;pointer-events:none;transform:translate(-50%,-50%);z-index:10;transition:width .1s,height .1s}.upload-zone{border:2px dashed var(--ink-15);border-radius:var(--radius-lg);padding:28px 20px;text-align:center;cursor:pointer;background:var(--surface);transition:all .2s;margin-bottom:12px}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--crimson);background:#a010200a}.upload-icon{font-size:36px;margin-bottom:8px}.upload-title{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:4px}.upload-sub{font-size:12px;color:var(--ink-60)}.matcher-container{max-width:1120px}.studio-start{display:block}.studio-hero{position:relative;overflow:hidden;border-radius:8px;margin-bottom:14px;min-height:230px;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(250px,.92fr);align-items:stretch;background:#10262e;color:#fff;box-shadow:var(--shadow-lg)}.studio-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#0a161cf0,#0a161cb8 42%,#0a161c33),url(https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1200&fit=crop&auto=format);background-size:cover;background-position:center;transform:scale(1.01)}.studio-hero-copy{position:relative;z-index:1;padding:28px;display:flex;flex-direction:column;justify-content:center;max-width:540px}.studio-kicker{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#9fd3c7;margin-bottom:10px}.studio-hero h1{font-family:var(--font-serif);font-size:clamp(28px,4.5vw,46px);font-weight:400;line-height:1.05;margin:0 0 12px;color:#fff;max-width:10ch}.studio-hero p{font-size:14px;line-height:1.65;color:#ffffffc2;max-width:440px;margin:0 0 18px}.studio-hero-actions{display:flex;gap:10px;flex-wrap:wrap}.studio-hero-actions .btn{min-width:138px}.studio-hero-art{position:relative;z-index:1;min-height:230px}.studio-swatch{position:absolute;border-radius:8px;border:2px solid rgba(255,255,255,.75);box-shadow:0 14px 32px #0000004d}.sw1{width:118px;height:118px;right:64px;top:32px;background:#c74837}.sw2{width:88px;height:88px;right:166px;bottom:34px;background:#d8a345}.sw3{width:74px;height:74px;right:32px;bottom:50px;background:#2a7468}.sw4{width:52px;height:52px;right:222px;top:56px;background:#f1e2c6}.studio-launch-grid{display:grid;grid-template-columns:minmax(280px,.9fr) minmax(320px,1.1fr);gap:14px;align-items:stretch;margin-bottom:14px}.studio-panel{background:#ffffffdb;border:1px solid rgba(26,22,18,.08);border-radius:8px;padding:14px;box-shadow:0 1px 2px #0000000a}.studio-panel-upload{display:flex;flex-direction:column}.studio-panel-upload .upload-zone{flex:1;min-height:176px;margin-bottom:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f9fbfa);border-color:#2a746859}.studio-panel-upload .upload-zone:hover,.studio-panel-upload .upload-zone.drag-over{border-color:#2a7468;background:#f2faf7}.studio-mini-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.studio-mini-steps span{border-radius:8px;background:#10262e;color:#ffffffd1;padding:7px 8px;font-size:11px;font-weight:650;text-align:center}.studio-mini-steps b{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#9fd3c7;color:#10262e;margin-right:4px;font-size:10px}.studio-panel-samples .section-label{margin-top:0;color:#2a7468}.studio-panel-samples .samples-grid{margin-bottom:0}.studio-session-button{width:100%;display:flex;align-items:center;gap:14px;padding:14px 16px;background:linear-gradient(90deg,#fff,#f2faf7);border:1.5px solid rgba(42,116,104,.45);border-radius:8px;cursor:pointer;font-family:var(--font);text-align:left;box-shadow:0 1px 2px #0000000a}.studio-section-head{margin-top:4px}.saved-photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:10px}.saved-photo-thumb{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1;background:var(--ink-05);cursor:pointer}.saved-photo-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.saved-photo-thumb:hover img{transform:scale(1.05)}.sp-del,.sp-dl{position:absolute;top:3px;width:22px;height:22px;border-radius:50%;border:none;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;font-weight:700}.sp-del{right:3px;background:#a01020d9;color:#fff}.sp-dl{right:28px;background:#0000008c;color:#fff}.sp-lbl{position:absolute;bottom:0;left:0;right:0;background:#0000008c;color:#fff;font-size:8px;padding:2px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.samples-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.sample-card{border-radius:8px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;position:relative;background:#10262e}.sample-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.sample-card:hover img{transform:scale(1.05)}.sample-card-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(0deg,#000000b8,#0000);color:#fff;font-size:10px;font-weight:800;padding:18px 8px 6px}#matcherPageDots{display:flex;justify-content:center;gap:8px;padding:6px 0}.page-dot{width:7px;height:7px;border-radius:50%;background:var(--ink-15);cursor:pointer;transition:all .15s}.page-dot.active{background:var(--crimson);transform:scale(1.3)}.recipe-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--ink-05)}.recipe-row:last-child{border-bottom:none}.recipe-pct{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--crimson);min-width:36px}.recipe-name{font-size:13px;font-weight:600}.recipe-sub{font-size:10px;color:var(--ink-60)}.recipe-display-toggle{display:flex;align-items:center;gap:4px;background:var(--ink-05);border-radius:var(--radius-pill);padding:3px;margin:0 0 10px}.recipe-display-toggle button{flex:1;border:0;border-radius:var(--radius-pill);padding:5px 8px;background:transparent;color:var(--ink-60);font-family:var(--font);font-size:11px;font-weight:800;cursor:pointer}.recipe-display-toggle button.active{background:var(--crimson);color:#fff}.recipe-portion-row{display:grid;grid-template-columns:minmax(90px,auto) 1fr;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--ink-05)}.recipe-portion-row:last-child{border-bottom:0}.recipe-blobs{display:flex;align-items:center;gap:4px;min-height:28px}.recipe-blob{display:inline-block;border-radius:50%;border:1.5px solid rgba(0,0,0,.14);box-shadow:inset 0 1px 2px #ffffff59}.recipe-help{border-top:1px solid var(--ink-10);padding-top:8px;margin-top:2px}.match-session-setup{margin:0 0 12px;background:#fff;border:1.5px solid var(--amber);border-radius:var(--radius-lg);overflow:hidden}.match-session-setup-head{padding:11px 14px;background:var(--amber);color:#fff;font-weight:800;font-size:13px}.match-session-setup-body{padding:12px 14px}.match-palette-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.match-palette-options button{border:1.5px solid var(--ink-15);border-radius:8px;background:#fff;padding:9px 6px;cursor:pointer;font-family:var(--font);text-align:center;color:var(--ink)}.match-palette-options button.active{border-color:var(--crimson);background:#c8182e14;box-shadow:0 0 0 1px #c8182e14}.match-palette-options strong{display:block;font-size:13px}.match-palette-options span{display:block;font-size:10px;color:var(--ink-60);line-height:1.35;margin-top:2px}.match-session-kit{margin-top:10px;background:var(--ink-05);border-radius:8px;padding:10px 12px;font-size:12px;color:var(--ink-75);line-height:1.55}.teacher-budget-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:10px}.teacher-budget-tile{background:var(--ink-05);border-radius:8px;padding:9px 10px}.teacher-budget-tile strong{display:block;font-size:16px;color:var(--ink);font-family:var(--font-serif)}.teacher-budget-tile span{font-size:10px;color:var(--ink-60);font-weight:700;text-transform:uppercase}@media(max-width:520px){.match-palette-options,.teacher-budget-grid,.recipe-portion-row{grid-template-columns:1fr}#su_wet,#su_dry,#su_gs,#su_ga{white-space:normal;line-height:1.2;min-width:0;padding-left:10px;padding-right:10px}#su_wet span,#su_dry span{display:block;margin-top:2px}}.paint-dot{width:52px;height:52px;border-radius:50%;transition:transform .15s}.paint-dot:hover{transform:scale(1.08)}.help-step{display:flex;gap:12px;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--ink-05)}.help-step:last-child{border-bottom:none}.help-step-num{min-width:28px;height:28px;border-radius:50%;background:var(--crimson);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}#helpContainer details[open]>summary>span:last-child{display:inline-block;transform:rotate(180deg);transition:transform .2s}#helpContainer details>summary>span:last-child{display:inline-block;transform:rotate(0);transition:transform .2s}#helpContainer details>summary{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.help-step-num[data-wired]{cursor:pointer;transition:transform .15s,box-shadow .15s}.help-step-num[data-wired]:hover{transform:scale(1.2);box-shadow:0 0 0 4px #a010202e}#vetSplash{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;cursor:pointer;background:linear-gradient(160deg,#1a1612,#2c1a10 60%,#1a1612)}@keyframes vetIn{0%{opacity:0;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}@keyframes vetOut{0%{opacity:1}to{opacity:0}}.stock-btn{width:36px;height:36px;border-radius:var(--radius);border:1.5px solid var(--ink-15);background:var(--surface);font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.stock-btn.plus:hover{background:var(--green-pale);border-color:var(--green)}.stock-btn.minus:hover{background:var(--crimson-pale);border-color:var(--crimson)}.text-crimson{color:var(--crimson)}.text-green{color:var(--green)}.text-amber{color:var(--amber)}.text-muted{color:var(--ink-60)}.text-sm{font-size:12px}.text-xs{font-size:10px}.font-mono{font-family:var(--font-mono)}.font-serif{font-family:var(--font-serif)}.font-bold{font-weight:700}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.hidden{display:none!important}@media(max-width:600px){.header-tagline{display:none}.app-clock{font-size:10px;padding:2px 7px;letter-spacing:.03em}.app-clock ._clk-date{display:none}.samples-grid{grid-template-columns:repeat(2,1fr)}.matcher-container{padding-left:12px;padding-right:12px}.studio-hero{grid-template-columns:1fr;min-height:0;margin-left:-2px;margin-right:-2px}.studio-hero:before{background:linear-gradient(180deg,#0a161cf0,#0a161cad),url(https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=900&fit=crop&auto=format);background-size:cover;background-position:center}.studio-hero-copy{padding:22px 18px 18px}.studio-hero h1{font-size:30px;max-width:12ch}.studio-hero p{font-size:13px;margin-bottom:14px}.studio-hero-actions .btn{flex:1;min-width:0}.studio-hero-art{display:none}.studio-launch-grid{grid-template-columns:1fr;gap:12px}.studio-panel{padding:12px}.studio-mini-steps{grid-template-columns:1fr}.studio-mini-steps span{text-align:left}:root{--side-pad:14px}.btn{min-height:44px}.btn-sm{min-height:40px}.icon-btn,.stock-btn,.zoom-btn{width:44px;height:44px}.sp-del,.sp-dl{width:28px;height:28px}*{-webkit-tap-highlight-color:transparent}button,a,[onclick]{touch-action:manipulation}#sortRecent,#sortAlpha{min-height:44px;padding:0 12px;display:inline-flex;align-items:center}#projectsList .btn{min-height:44px!important}#palettesList button,#historyList button{min-height:44px;min-width:44px}#adminPanel .btn{min-height:44px!important}}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-thumb{background:var(--ink-15);border-radius:2px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:28px;height:28px;border-radius:50%;border:3px solid var(--ink-10);border-top-color:var(--crimson);animation:spin .8s linear infinite;display:inline-block}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#f5f0e8e0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border-radius:var(--radius);z-index:20;font-size:13px;color:var(--ink-60);font-weight:600}@keyframes dotPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.8);opacity:.5}to{transform:translate(-50%,-50%) scale(1);opacity:0}}#heicToast{display:none;position:fixed;top:calc(var(--content-top) + 8px);left:50%;transform:translate(-50%);z-index:800;background:var(--ink);color:#fff;padding:10px 18px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;box-shadow:var(--shadow-lg);white-space:nowrap;max-width:90vw;text-align:center}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overscroll-behavior-x:none;overscroll-behavior-y:auto}html{overscroll-behavior:none}@keyframes _tabIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.tab-content.tab-visible{animation:_tabIn .18s cubic-bezier(.4,0,.2,1)}.btn{transition:transform .12s,opacity .12s,background .15s,box-shadow .15s}.btn:active{transform:scale(.95);opacity:.88}.btn-crimson:active{background:var(--crimson-dark)}.btn-outline:active{background:var(--ink-05)}.icon-btn{transition:transform .12s,background .15s,border-color .15s}.icon-btn:active{transform:scale(.88)}.colour-dot{transition:transform .15s,box-shadow .15s}.colour-dot:active{transform:scale(.92)!important}.drawer-btn{transition:transform .12s,background .15s,border-color .15s}.drawer-btn:active{transform:scale(.92)}.stock-btn,.zoom-btn{transition:transform .12s,background .15s}.stock-btn:active,.zoom-btn:active{transform:scale(.88)}.upload-zone:active{transform:scale(.98)}.sample-card{transition:transform .15s,box-shadow .15s}.sample-card:active{transform:scale(.95);border-radius:var(--radius)}.bottom-nav{background:#ffffffe0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.06);box-shadow:0 -1px #0000000a,0 -4px 20px #0000000f;padding-bottom:max(env(safe-area-inset-bottom,0px),4px)}.desktop-tab-bar{background:#ffffffe6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,.06)}.app-header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}#stickyColourBar{background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(0,0,0,.06)}#moreDrawer{background:#fffffff2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.loading-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.toast{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#1a1612eb;box-shadow:0 4px 24px #00000038;font-weight:600;letter-spacing:.01em}.nav-tab.active:before{width:28px;height:3px;border-radius:0 0 3px 3px;background:linear-gradient(90deg,var(--crimson-light),var(--crimson))}.nav-tab{transition:background .1s}.nav-tab:active{background:#a010200f}.nav-icon{transition:transform .15s}.nav-tab.active .nav-icon{transform:scale(1.08)}#matcherPageDots{background:#ffffffe6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.05);padding:8px 0}.page-dot{width:8px;height:8px;cursor:pointer;transition:width .25s,height .25s,background .2s}.page-dot.active{width:22px;border-radius:4px;background:var(--crimson)}.card{border:none;box-shadow:0 1px 2px #0000000f,0 2px 8px #0000000a;transition:box-shadow .2s}.recipe-swatch{transition:background .35s}.recipe-bar-fill{transition:width .5s cubic-bezier(.4,0,.2,1)}.photo-wrap{background:#0a0a0a}.form-input{border:1.5px solid var(--ink-15);background:var(--surface);transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--crimson);box-shadow:0 0 0 3px #a010201a;outline:none}.form-select{border:1.5px solid var(--ink-15);background:var(--surface);transition:border-color .15s;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}@media(max-width:768px){::-webkit-scrollbar{display:none}*{scrollbar-width:none}}@media(max-width:768px){input,textarea,select,.form-input{font-size:16px!important}}.tab-btn{transition:color .15s,background .15s,border-color .15s}.tab-btn:active{background:var(--crimson-pale)}.tab-hero{padding:16px 20px 14px;position:relative;overflow:hidden}.tab-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 60%);pointer-events:none}.section-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-40);padding:12px 0 6px;margin:0}button,.nav-tab,.tab-btn,.drawer-btn,.colour-dot,.page-dot,.sample-card{user-select:none;-webkit-user-select:none}details summary{list-style:none;-webkit-tap-highlight-color:transparent}details summary::-webkit-details-marker{display:none}#vetSplash{background:linear-gradient(160deg,#0e0404,#1c0806,#0e0404)}#stickyDotRow .colour-dot{box-shadow:0 2px 8px #00000026,0 0 0 2px #fff}#stickyDotRow .colour-dot:active{transform:scale(.9)!important}.ai-pill{animation:_aiPulse 3s ease-in-out infinite}@keyframes _aiPulse{0%,to{opacity:1}50%{opacity:.75}}@keyframes _rp{0%{width:32px;height:32px;opacity:.8}to{width:80px;height:80px;opacity:0;margin-left:-24px;margin-top:-24px}}@keyframes _dotPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}#_photoActionBar{position:fixed;top:calc(var(--content-top) + var(--toolbar-h));left:0;right:0;height:44px;z-index:479;display:none;background:var(--surface);border-bottom:1px solid var(--ink-10);gap:8px;align-items:center;padding:0 var(--side-pad);flex-wrap:nowrap}body.photo-loaded.matcher-active #_photoActionBar{display:flex}@media(max-width:768px){#_photoActionBar{top:calc(var(--header-h) + var(--toolbar-h))}}#_activeProjectChip{display:none;background:var(--amber-pale);border-left:3px solid var(--amber);border-radius:var(--radius);padding:8px 12px;margin-bottom:10px;align-items:center;gap:10px;flex-wrap:nowrap}#_activeProjectChip.active{display:flex}#_onboardOverlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:999999;background:var(--mahogany);flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 28px}#_onboardOverlay.active{display:flex}#_qnavFab{position:fixed;right:16px;bottom:calc(82px + env(safe-area-inset-bottom,0px));width:48px;height:48px;border-radius:50%;background:var(--mahogany);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #00000059;z-index:800;transition:transform .15s,box-shadow .15s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}#_qnavFab:active{transform:scale(.92);box-shadow:0 2px 8px #0000004d}@media(min-width:769px){#_qnavFab{bottom:24px}}@media(max-width:768px){#_qnavFab{display:none!important}}#_qnavBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:849;display:none;pointer-events:none;transition:background .25s}#_qnavBackdrop.open{background:#00000073}#_qnavSheet{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-radius:20px 20px 0 0;z-index:850;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:80vh;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom,16px)}#_qnavSheet.open{transform:translateY(0)}#_qnavHandle{width:36px;height:4px;border-radius:2px;background:var(--ink-15);margin:12px auto 4px}#_qnavSheetTitle{text-align:center;font-size:13px;font-weight:700;color:var(--ink-60);letter-spacing:.06em;text-transform:uppercase;padding:0 20px 14px;border-bottom:1px solid var(--ink-15);margin-bottom:4px}._qnavItem{display:flex;align-items:center;gap:14px;padding:14px 20px;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;font-family:var(--font);transition:background .1s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}._qnavItem:active{background:var(--bg)}._qnavItemIcon{font-size:22px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:10px;flex-shrink:0}._qnavItemLabel{font-size:15px;font-weight:700;color:var(--ink);line-height:1.2;margin-bottom:2px}._qnavItemSub{font-size:12px;color:var(--ink-60);line-height:1.3}._qnavDivider{height:1px;background:var(--ink-15);margin:0 20px}@media(min-width:520px){#_lenGrid{grid-template-columns:1fr 1fr!important}}#fm-container{min-height:calc(100vh - 200px)}.fm-root{display:flex;flex-direction:column;font-size:13px;color:var(--ink)}.fm-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:8px 10px;background:var(--surface);border-bottom:1px solid var(--ink-10);position:sticky;top:var(--content-top);z-index:100}.fm-tb-group{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.fm-tb-sep{width:1px;height:20px;background:var(--ink-15);margin:0 4px;flex-shrink:0}.fm-tb-btn{display:flex;align-items:center;gap:4px;padding:5px 8px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--ink-80);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .1s}.fm-tb-btn:hover:not(:disabled){background:var(--ink-05)}.fm-tb-btn:disabled{opacity:.38;cursor:default}.fm-tb-btn--active{background:var(--crimson-pale)!important;color:var(--crimson)}.fm-tb-btn--danger:hover:not(:disabled){background:#fee;color:#b00}.fm-tb-search{flex:1;min-width:120px;max-width:260px}.fm-search-input{width:100%;padding:5px 10px;border:1px solid var(--ink-15);border-radius:var(--radius-pill);font-size:12px;background:var(--bg);color:var(--ink)}.fm-search-input:focus{outline:none;border-color:var(--crimson)}.fm-search-input:disabled{opacity:.4}.fm-tb-sort{display:flex;align-items:center;gap:4px}.fm-sort-select{padding:4px 6px;border:1px solid var(--ink-15);border-radius:var(--radius-sm);font-size:12px;background:var(--bg);color:var(--ink)}.fm-sort-select:disabled{opacity:.4}.fm-body{display:flex;flex:1;min-height:0}.fm-main{flex:1;min-width:0;display:flex;flex-direction:column}.fm-breadcrumbs{display:flex;align-items:center;gap:4px;padding:8px 12px;font-size:12px;background:var(--bg);border-bottom:1px solid var(--ink-10);flex-wrap:wrap;min-height:38px}.fm-bc-link{background:none;border:none;color:var(--crimson);font-size:12px;cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm)}.fm-bc-link:hover{background:var(--crimson-pale)}.fm-bc-current{font-weight:700;color:var(--ink)}.fm-bc-sep{color:var(--ink-40);-webkit-user-select:none;user-select:none}.fm-content-area{flex:1;overflow-y:auto;min-height:300px}.fm-loading{display:flex;align-items:center;justify-content:center;min-height:120px;color:var(--ink-60);font-size:13px}.fm-error{padding:16px;color:#c00;background:#fee;border-radius:var(--radius);margin:12px}.fm-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:260px;padding:32px 20px;text-align:center}.fm-empty-icon{font-size:48px;margin-bottom:12px}.fm-empty-title{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:6px}.fm-empty-sub{font-size:13px;color:var(--ink-60);line-height:1.6;max-width:320px}.fm-compat-note{font-size:12px;color:var(--amber);background:var(--amber-pale);padding:8px 14px;border-radius:var(--radius-sm)}.fm-compat-banner{font-size:12px;color:var(--ink-60);background:var(--bg);padding:6px 12px;border-bottom:1px solid var(--ink-10);text-align:center}.fm-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-pill);border:1px solid var(--ink-15);background:var(--surface);color:var(--ink);font-size:13px;font-weight:600;cursor:pointer;transition:background .1s,box-shadow .1s}.fm-btn:hover{background:var(--bg);box-shadow:var(--shadow-sm)}.fm-btn-primary{background:var(--crimson);color:#fff;border-color:var(--crimson)}.fm-btn-primary:hover{background:var(--crimson-dark);border-color:var(--crimson-dark)}.fm-btn-danger{background:#c00;color:#fff;border-color:#c00}.fm-btn-danger:hover{background:#a00;border-color:#a00}.fm-list{display:flex;flex-direction:column}.fm-list-header,.fm-list-row{display:grid;grid-template-columns:28px 1fr 90px 72px 100px;gap:0;align-items:center;padding:6px 12px;border-bottom:1px solid var(--ink-10)}.fm-list-header{font-size:11px;font-weight:700;color:var(--ink-60);text-transform:uppercase;letter-spacing:.04em;background:var(--bg);position:sticky;top:0}.fm-list-row{background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.fm-list-row:hover{background:var(--bg)}.fm-list-row.fm-selected{background:var(--crimson-pale)}.fm-list-row.fm-drag-over{background:var(--crimson-pale);outline:2px dashed var(--crimson);outline-offset:-2px}.fm-list-row.fm-dragging{opacity:.5}.fm-list-icon{font-size:16px;display:flex;align-items:center}.fm-list-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fm-list-type,.fm-list-size,.fm-list-date{font-size:11px;color:var(--ink-60);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;padding:12px}.fm-grid-card{display:flex;flex-direction:column;align-items:center;padding:12px 6px;border-radius:var(--radius);border:2px solid transparent;background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s,border-color .1s}.fm-grid-card:hover{background:var(--bg);border-color:var(--ink-10)}.fm-grid-card.fm-selected{background:var(--crimson-pale);border-color:var(--crimson)}.fm-grid-card.fm-drag-over{border:2px dashed var(--crimson)}.fm-grid-icon{font-size:32px;margin-bottom:6px;line-height:1}.fm-grid-name{font-size:11px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:88px;color:var(--ink-80)}.fm-preview{width:280px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--ink-10);background:var(--surface);overflow:hidden}.fm-preview-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--ink-10);gap:8px}.fm-preview-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.fm-preview-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:var(--radius-sm);font-size:16px;color:var(--ink-60);line-height:1}.fm-preview-close:hover{background:var(--ink-10)}.fm-preview-meta{display:flex;gap:8px;padding:6px 12px;font-size:11px;color:var(--ink-60);flex-wrap:wrap;border-bottom:1px solid var(--ink-10)}.fm-preview-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:12px}.fm-preview-img{max-width:100%;max-height:360px;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.fm-preview-pdf{width:100%;height:360px;border:none}.fm-preview-text{font-family:var(--font-mono);font-size:11px;white-space:pre-wrap;word-break:break-all;color:var(--ink);width:100%;max-height:480px;overflow-y:auto;background:var(--bg);padding:8px;border-radius:var(--radius-sm)}.fm-preview-truncated{font-size:11px;color:var(--ink-40);margin-top:6px;align-self:flex-start}.fm-preview-audio,.fm-preview-video{width:100%;margin-top:8px}.fm-preview-nopreview{display:flex;flex-direction:column;align-items:center;padding:20px;text-align:center;gap:8px;font-size:13px;color:var(--ink-60)}.fm-ctx-menu{position:fixed;z-index:2000;background:var(--surface);border:1px solid var(--ink-15);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:4px 0;min-width:160px;animation:_fadeIn .1s ease}.fm-ctx-item{padding:8px 16px;font-size:13px;cursor:pointer;color:var(--ink)}.fm-ctx-item:hover{background:var(--bg)}.fm-ctx-danger{color:#c00}.fm-ctx-danger:hover{background:#fee}.fm-ctx-sep{height:1px;background:var(--ink-10);margin:4px 0}.fm-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px}.fm-dialog{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:380px;width:100%;overflow:hidden;animation:_slideUp .18s ease}.fm-dialog-title{padding:18px 20px 0;font-size:15px;font-weight:700;color:var(--ink)}.fm-dialog-body{padding:12px 20px;color:var(--ink-80);font-size:13px;line-height:1.6}.fm-dialog-footer{display:flex;gap:8px;padding:12px 20px;border-top:1px solid var(--ink-10);justify-content:flex-end}.fm-label{display:block;font-size:12px;font-weight:600;color:var(--ink-60);margin-bottom:6px}.fm-input{width:100%;padding:8px 12px;border:1px solid var(--ink-15);border-radius:var(--radius-sm);font-size:13px;color:var(--ink);background:var(--bg)}.fm-input:focus{outline:none;border-color:var(--crimson)}@media(max-width:680px){.fm-preview{display:none!important}.fm-toolbar{top:var(--header-h)}.fm-list-type,.fm-list-date{display:none}.fm-list-header,.fm-list-row{grid-template-columns:28px 1fr 72px}.fm-tb-btn span{display:none}.fm-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}
