:root{
--bg:#f4f6fb;--surface:#fff;--surface-2:#f8fafc;--border:#e6e9f0;--border-2:#eef1f6;
--text:#1f2433;--text-soft:#5b6478;--text-faint:#8a93a6;
--primary:#c1272d;--primary-dark:#a31f24;
--shadow:0 1px 2px rgba(20,25,50,.05),0 4px 14px rgba(20,25,50,.05);--radius:11px;
--green:#1f9d5b;--amber:#c9821a;--red:#c1272d;--blue:#2563c9;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:13px;line-height:1.4}
.hidden{display:none!important}
/* auth screens */
.center-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.spinner{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.login-card{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:30px 34px;text-align:center;max-width:360px;width:92%}
.login-card h1{font-size:22px;margin:14px 0 2px}
.login-card .sub{color:var(--text-soft);margin:0 0 16px;font-size:13px}
.login-card .ic{font-size:30px}
.gbtn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;border:1px solid var(--border);border-radius:10px;background:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.gbtn:hover{background:var(--surface-2)}
.gbtn svg{width:18px;height:18px}
.login-note{color:var(--text-faint);font-size:11.5px;margin-top:14px;line-height:1.5}
.login-err{background:#fdeeef;border:1px solid #f0c4c6;color:var(--primary-dark);border-radius:9px;padding:9px;font-size:12.5px;margin-bottom:12px}
#toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#1f2433;color:#fff;padding:9px 16px;border-radius:9px;font-size:13px;opacity:0;pointer-events:none;transition:opacity .2s;z-index:60}
#toast.show{opacity:1}
/* app shell */
.app{display:grid;grid-template-columns:188px 1fr;grid-template-rows:50px 52px 1fr;height:100vh}
.topbar{grid-column:1/3;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 14px}
.brandmark{width:26px;height:26px;border-radius:7px;background:var(--primary);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.5px}
.brandmark.lg{width:46px;height:46px;border-radius:12px;font-size:18px;margin:0 auto}
.brandname{font-weight:700;font-size:14px}
.topsearch{margin-left:14px;flex:1;max-width:340px;padding:6px 11px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);font-size:12.5px;font-family:inherit}
.spacer{flex:1}
.who{font-size:12.5px;color:var(--text-soft)}
.avatar{width:26px;height:26px;border-radius:50%;background:#dfe4ee;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text-soft);font-size:11px}
.scopebar{grid-column:1/3;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:20px;padding:0 18px;box-shadow:var(--shadow)}
.scopebar .lead{display:flex;align-items:center;gap:7px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);font-weight:600}
.scopebar .lead .dot{width:8px;height:8px;border-radius:50%;background:var(--primary)}
.sg{display:flex;align-items:center;gap:8px}
.sg label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint)}
.sg select{font-size:14px;font-weight:600;padding:7px 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);cursor:pointer;font-family:inherit;color:var(--text);min-width:150px}
.scopebar .hintr{margin-left:auto;font-size:11px;color:var(--text-faint)}
select,.btn{font-family:inherit;font-size:12.5px;color:var(--text)}
select{background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:5px 8px;cursor:pointer}
.btn{background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:6px 11px;cursor:pointer}
.btn.pri{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}
.btn.sm{padding:4px 9px;font-size:12px}
.side{grid-row:3;background:var(--surface);border-right:1px solid var(--border);padding:8px;display:flex;flex-direction:column;gap:1px}
.nav{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:8px;color:var(--text-soft);cursor:pointer;font-weight:500;font-size:13px}
.nav:hover{background:var(--surface-2)}
.nav.active{background:#fbeaea;color:var(--primary);font-weight:600}
.nav .ic{width:15px;text-align:center;font-size:13px}
.side .grp{font-size:9.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);padding:11px 10px 4px}
.main{grid-row:3;overflow:auto;padding:14px 18px}
.h1{font-size:16px;font-weight:700;margin:0}
.sub{color:var(--text-soft);margin:1px 0 12px;font-size:12px}
.rowflex{display:flex;align-items:center;justify-content:space-between;gap:10px}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:14px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px;position:relative;overflow:hidden}
.kpi .accent{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary)}
.kpi .label{font-size:10px;color:var(--text-soft);text-transform:uppercase;letter-spacing:.4px}
.kpi .value{font-size:21px;font-weight:700;margin-top:3px;line-height:1.1}
.kpi .sub2{font-size:11px;color:var(--text-faint);margin-top:1px}
.filters{display:flex;gap:7px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.search{flex:1;min-width:160px;padding:6px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:inherit;font-size:12.5px}
.chiprow{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.fchip{font-size:11.5px;color:var(--text-soft);background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:3px 9px}
.fchip b{color:var(--text)}
.clear{font-size:11.5px;color:var(--primary);cursor:pointer}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{background:var(--surface-2);text-align:left;font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.4px;padding:7px 11px;font-weight:600;cursor:pointer;white-space:nowrap;user-select:none}
thead th.sorted{color:var(--primary)}
thead th .ar{font-size:9px}
tbody td{padding:7px 11px;border-top:1px solid var(--border-2);font-size:13px;vertical-align:middle}
tbody tr{cursor:pointer}
tbody tr:hover{background:var(--surface-2)}
.name{font-weight:600}
.muted{color:var(--text-faint);font-size:11.5px}
.path{color:var(--text-soft)}
.rt{text-align:right}
.empty{padding:26px;text-align:center;color:var(--text-faint);font-size:12.5px}
.pill{display:inline-block;padding:1px 8px;border-radius:20px;font-size:11px;font-weight:600;line-height:1.7;white-space:nowrap}
.veg{color:#1f9d5b;border:1px solid #b9e3cc;background:#eefaf2}
.nonveg{color:#c1272d;border:1px solid #f0c4c6;background:#fdeeef}
.egg{color:#c9821a;border:1px solid #efd9b4;background:#fdf5e8}
.tag{background:#eef1f7;color:var(--text-soft);border:1px solid var(--border);margin-right:3px}
.on{color:#1f9d5b;border:1px solid #b9e3cc;background:#eefaf2}
.off{color:var(--text-faint);border:1px solid var(--border);background:var(--surface-2)}
.hub{color:#2563c9;border:1px solid #c2d4f2;background:#eef4fe}
.cls{font-weight:700;font-size:12.5px}
.cls.Star{color:#1f9d5b}.cls.Plowhorse{color:#c9821a}.cls.Puzzle{color:#2563c9}.cls.Dog{color:#8a93a6}
.fc-g{color:var(--green);font-weight:600}.fc-a{color:var(--amber);font-weight:600}.fc-r{color:var(--red);font-weight:600}
.price{font-weight:600}
.iconbtn{color:var(--text-faint);cursor:pointer;padding:2px 5px;border-radius:6px;font-size:13px}
.iconbtn:hover{background:#eef1f7;color:var(--text)}
.swatch{display:inline-block;width:12px;height:12px;border-radius:3px;vertical-align:-1px;margin-right:6px;border:1px solid rgba(0,0,0,.1)}
.scrim{position:fixed;inset:0;background:rgba(20,25,50,.32);display:none;z-index:20}
.scrim.open{display:block}
.drawer{position:fixed;top:0;right:0;height:100vh;width:540px;max-width:94vw;background:var(--surface);box-shadow:-12px 0 40px rgba(20,25,50,.18);transform:translateX(100%);transition:transform .2s ease;display:flex;flex-direction:column;z-index:30}
.drawer.open{transform:none}
.dh{padding:13px 18px;border-bottom:1px solid var(--border)}
.dh .x{float:right;cursor:pointer;color:var(--text-faint);font-size:19px;line-height:1}
.dh .t{font-size:16px;font-weight:700}
.dh .id{color:var(--text-faint);font-size:11.5px;margin-top:1px}
.tabs{display:flex;gap:2px;padding:0 12px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.tab{padding:9px 11px;font-size:12.5px;color:var(--text-soft);cursor:pointer;border-bottom:2px solid transparent}
.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
.dbody{padding:14px 18px;overflow:auto}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
.field .l{font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-faint)}
.field .v{font-size:13.5px;margin-top:1px}
.matrix{width:100%;border-collapse:collapse;margin-top:4px;font-size:12.5px}
.matrix th,.matrix td{border:1px solid var(--border-2);padding:7px 9px;text-align:center}
.matrix th{background:var(--surface-2);font-size:10px;color:var(--text-faint);text-transform:uppercase}
.matrix td.lab{text-align:left;font-weight:600;background:#fff}
.hint{font-size:11.5px;color:var(--text-faint);margin-top:6px}
.quad{position:relative;height:300px;background:#fff;border:1px solid var(--border);border-radius:11px}
.quad .q{position:absolute;width:50%;height:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-faint);opacity:.45}
.q.tl{left:0;top:0;border-right:1px dashed var(--border);border-bottom:1px dashed var(--border)}
.q.tr{right:0;top:0;border-bottom:1px dashed var(--border)}
.q.bl{left:0;bottom:0;border-right:1px dashed var(--border)}
.q.br{right:0;bottom:0}
.dot{position:absolute;width:12px;height:12px;border-radius:50%;transform:translate(-50%,50%);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.dot span{position:absolute;left:14px;top:-4px;white-space:nowrap;font-size:10.5px;color:var(--text-soft)}
.axislbl{position:absolute;font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.4px}
.mwrap{display:grid;grid-template-columns:198px 1fr;gap:14px;align-items:start}
.mlist{background:var(--surface);border:1px solid var(--border);border-radius:11px;box-shadow:var(--shadow);overflow:hidden;padding:6px}
.mlist .g{font-size:9.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);padding:9px 9px 4px}
.mi{display:flex;align-items:center;justify-content:space-between;padding:6px 9px;border-radius:7px;cursor:pointer;color:var(--text-soft);font-size:12.5px}
.mi:hover{background:var(--surface-2)}
.mi.active{background:#fbeaea;color:var(--primary);font-weight:600}
.mi .ct{font-size:10.5px;color:var(--text-faint);background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:0 7px;min-width:20px;text-align:center}
.mi.active .ct{color:var(--primary);border-color:#f0c4c6;background:#fff}
.mi .hublink{font-size:9px;color:#2563c9}
.mpane .phead{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.mpane .ptitle{font-size:15px;font-weight:700}
.mpane .pcount{color:var(--text-faint);font-size:12px;font-weight:500;margin-left:6px}
.banner{display:flex;align-items:center;gap:9px;background:#eef4fe;border:1px solid #c2d4f2;color:#1e4ea8;border-radius:9px;padding:9px 12px;font-size:12px;margin:0 14px 4px}
.banner a{color:#1e4ea8;font-weight:700;text-decoration:none;white-space:nowrap;cursor:pointer}
.catwrap{display:grid;grid-template-columns:230px 1fr;gap:0}
.catL{border-right:1px solid var(--border)}
.catL .ci{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-bottom:1px solid var(--border-2);cursor:pointer}
.catL .ci:hover{background:var(--surface-2)}
.catL .ci.active{background:#fbeaea;color:var(--primary);font-weight:600}
.catL .ci .ct{font-size:10.5px;color:var(--text-faint)}
.catR{padding:12px 14px}
.subchip{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:5px 10px;margin:0 7px 7px 0;font-size:12.5px}
.subchip .del{color:var(--text-faint);cursor:pointer;font-size:13px}
.subchip .del:hover{color:var(--primary)}
.steps{display:flex;gap:8px;margin:4px 0 14px}
.step{flex:1;background:#fff;border:1px solid var(--border);border-radius:10px;padding:11px 13px}
.step .n{width:20px;height:20px;border-radius:50%;background:#fbeaea;color:var(--primary);font-weight:700;font-size:11px;display:inline-flex;align-items:center;justify-content:center;margin-right:7px}
.step .t{font-weight:600;font-size:12.5px}
.step .d{color:var(--text-faint);font-size:11px;margin-top:4px}
.drop{border:1.5px dashed #cdd3df;border-radius:11px;background:var(--surface-2);padding:22px;text-align:center;color:var(--text-soft)}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:10px}
.tile{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;cursor:pointer}
.tile:hover{border-color:#cdd3df;box-shadow:var(--shadow)}
.tile .tt{font-weight:600;font-size:13px}
.tile .td{color:var(--text-faint);font-size:11px;margin-top:2px}
.match{color:var(--green);font-weight:600}.mis{color:var(--amber);font-weight:600}
.mmscrim{position:fixed;inset:0;background:rgba(20,25,50,.34);display:none;align-items:center;justify-content:center;z-index:40}
.mmscrim.open{display:flex}
.modal{background:#fff;border-radius:13px;width:420px;max-width:92vw;box-shadow:0 20px 60px rgba(20,25,50,.25);overflow:hidden}
.modal .mh{padding:13px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:14px}
.modal .mb{padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.modal label{font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-faint);display:block;margin-bottom:3px}
.modal input,.modal select{width:100%;padding:7px 9px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit}
.modal .mf{padding:12px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
.vchip{display:inline-block;font-size:12px;border:1px solid var(--border);background:var(--surface-2);border-radius:20px;padding:3px 11px;cursor:pointer;color:var(--text-soft);margin:0 5px 5px 0}
.vchip.on{background:#fbeaea;border-color:#f0c4c6;color:var(--primary);font-weight:600}
.baseblk{margin:8px 0 12px;padding:11px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2)}
.ap{display:flex;align-items:center;gap:5px;font-weight:600;margin-top:4px}
.ap input,.basep,.areap{padding:6px 9px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit}
.arealist{border:1px solid var(--border);border-radius:10px;overflow:hidden}
.arehead{display:grid;grid-template-columns:1fr 130px 56px;gap:8px;padding:7px 12px;background:var(--surface-2);font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-faint)}
.arearow{display:grid;grid-template-columns:1fr 130px 56px;gap:8px;align-items:center;padding:8px 12px;border-top:1px solid var(--border-2)}
.arearow .an{font-weight:600;font-size:13px}
.arearow .areap{width:108px}
.sw input{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}
.sect{font-size:12.5px;font-weight:700;margin:0 0 9px;color:var(--text)}
.form{display:grid;grid-template-columns:1fr 1fr;gap:11px 16px}
.form .full{grid-column:1/3}
.fld label{font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-faint);display:block;margin-bottom:3px}
.fld input,.fld select,.fld textarea{width:100%;padding:7px 9px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;color:var(--text)}
.fld textarea{resize:vertical;min-height:46px}
.locked{background:var(--surface-2);color:var(--text-soft)}
.tagpick{display:flex;flex-wrap:wrap;gap:6px}
.tagopt{font-size:12px;border:1px solid var(--border);background:#fff;border-radius:20px;padding:4px 11px;cursor:pointer;color:var(--text-soft)}
.tagopt.sel{background:#fbeaea;border-color:#f0c4c6;color:var(--primary);font-weight:600}
.back{font-size:12px;color:var(--text-soft);cursor:pointer}
.back:hover{color:var(--primary)}
.imgph{width:92px;height:92px;border-radius:10px;background:var(--surface-2);border:1px dashed #cdd3df;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-faint);font-size:11px;cursor:pointer;flex:none}
.imgph:hover{border-color:var(--primary);color:var(--primary)}
