:root{--brand: #A08BCB;--brand-deep: #725E99;--brand-darker: #5B4787;--brand-soft: #EAE2F5;--bg: #F7F4FB;--card: #FFFFFF;--ink: #2C2537;--ink-2: #5B5469;--ink-3: #9A93AA;--line: rgba(44, 37, 55, .1);--line-soft: rgba(44, 37, 55, .06);--success: #5B8C6E;--warning: #C49A4A;--danger: #B96A6A;--success-soft: #E6EFE9;--warning-soft: #F4ECDB;--danger-soft: #F1E0E0}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);font-family:-apple-system,PingFang SC,Microsoft YaHei,Segoe UI,system-ui,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}.serif{font-family:Cormorant Garamond,Georgia,Songti SC,serif}.tnum{font-variant-numeric:tabular-nums}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit}.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f7f4fb,#eae2f5);padding:24px}.login-card{width:380px;max-width:100%;background:var(--card);border-radius:20px;padding:40px 36px;box-shadow:0 24px 60px #5b478729}.login-brand{font-size:40px;font-weight:600;color:var(--brand-darker);letter-spacing:1px;line-height:1}.login-sub{font-size:13px;color:var(--brand);font-style:italic;font-family:Cormorant Garamond,Georgia,serif;margin-top:2px}.login-title{font-size:18px;font-weight:700;color:var(--ink);margin-top:24px}.login-note{font-size:13px;color:var(--ink-2);background:var(--brand-soft);border-radius:10px;padding:10px 12px;margin-top:12px;line-height:1.6}.field{display:block;margin-top:18px}.field span{display:block;font-size:13px;color:var(--ink-2);margin-bottom:6px}.field input{width:100%;height:44px;border:1.5px solid var(--line);border-radius:10px;padding:0 14px;font-size:15px;color:var(--ink);outline:none;transition:border-color .15s}.field input:focus{border-color:var(--brand)}.login-err{margin-top:14px;font-size:13px;color:var(--danger)}.login-hint{margin-top:14px;font-size:13px;color:var(--success)}.login-btn{width:100%;margin-top:24px}.qr-area{margin-top:22px;min-height:290px;display:flex;flex-direction:column;align-items:center;justify-content:center}.qr-img{width:220px;height:220px;border-radius:12px;border:1px solid var(--line)}.qr-ph{color:var(--ink-3);font-size:14px}.qr-tip{margin-top:16px;font-size:13px;color:var(--ink-2);text-align:center;line-height:1.7}.qr-tip b{color:var(--brand-darker)}.qr-state{text-align:center;padding:40px 0}.qr-state-t{font-size:16px;font-weight:700;color:var(--danger)}.qr-state-s{font-size:13px;color:var(--ink-2);margin-top:8px;line-height:1.6}.btn-primary{height:44px;padding:0 22px;background:var(--brand-deep);color:#fff;border-radius:10px;font-size:15px;font-weight:600;transition:opacity .15s}.btn-primary:hover{opacity:.92}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{height:34px;padding:0 16px;background:#fff;color:var(--brand-darker);border:1.5px solid var(--line);border-radius:8px;font-size:13px;font-weight:600}.btn-ghost:hover{border-color:var(--brand)}.layout{display:flex;height:100%}.sidebar{width:232px;flex-shrink:0;background:linear-gradient(180deg,#6e5b95,#5b4787 60%,#4a3978);color:#fff;display:flex;flex-direction:column;padding:28px 18px}.brand{padding:0 10px 24px;border-bottom:1px solid rgba(255,255,255,.12)}.brand-name{font-size:30px;font-weight:600;letter-spacing:1px}.brand-sub{font-size:12px;color:#fff9;margin-top:4px}.nav{display:flex;flex-direction:column;gap:4px;margin-top:20px;flex:1}.nav-item{text-align:left;padding:12px 14px;border-radius:10px;font-size:15px;color:#ffffffb3;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#ffffff29;color:#fff;font-weight:600}.side-foot{border-top:1px solid rgba(255,255,255,.12);padding-top:16px}.side-user{display:flex;align-items:center;gap:8px;padding:0 10px;margin-bottom:12px}.side-user-name{font-size:14px;font-weight:600}.role-tag{font-size:11px;padding:2px 8px;border-radius:999px;background:#ffffff2e;color:#fff}.logout-btn{width:100%;height:38px;border-radius:9px;border:1px solid rgba(255,255,255,.25);color:#ffffffd9;font-size:13px;transition:background .15s}.logout-btn:hover{background:#ffffff1a}.content{flex:1;min-width:0;overflow-y:auto;padding:32px 36px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.page-head h2{font-size:22px;font-weight:700;color:var(--ink)}.empty{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:60px 0;text-align:center;color:var(--ink-3);font-size:14px}.filters{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.chip{height:34px;padding:0 16px;border-radius:999px;background:#fff;border:1.5px solid var(--line);color:var(--ink-2);font-size:13px;font-weight:600;transition:all .15s}.chip:hover{border-color:var(--brand)}.chip.on{background:var(--brand-deep);border-color:var(--brand-deep);color:#fff}.card{background:var(--card);border:1px solid var(--line);border-radius:14px}.table-card{overflow:hidden}.tbl{width:100%;border-collapse:collapse;font-size:14px}.tbl thead th{text-align:left;padding:14px 16px;background:#fcfafe;color:var(--ink-2);font-weight:600;font-size:13px;border-bottom:1px solid var(--line);white-space:nowrap}.tbl tbody td{padding:14px 16px;border-bottom:1px solid var(--line-soft);color:var(--ink);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:#fcfafe}.note-cell{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink-2)}.order-no{font-size:12px;color:var(--ink-3)}.col-ops{white-space:nowrap}.st{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.st-pending{background:var(--warning-soft);color:var(--warning)}.st-confirmed{background:var(--brand-soft);color:var(--brand-deep)}.st-visited{background:var(--success-soft);color:var(--success)}.st-canceled{background:var(--danger-soft);color:var(--danger)}.op{height:30px;padding:0 12px;border-radius:7px;font-size:12px;font-weight:600;background:#fff;border:1px solid var(--line);color:var(--ink-2);margin-right:6px;transition:all .15s}.op:last-child{margin-right:0}.op:hover{border-color:var(--brand)}.op-primary{background:var(--brand-deep);border-color:var(--brand-deep);color:#fff}.op-primary:hover{opacity:.9}.op-danger{background:var(--danger-soft);border-color:transparent;color:var(--danger)}.op-none{color:var(--ink-3)}.head-actions{display:flex;gap:10px}.btn-sm{height:34px;padding:0 16px;font-size:13px;border-radius:8px}.hint-bar{background:var(--warning-soft);color:var(--warning);font-size:13px;padding:10px 14px;border-radius:8px;margin-bottom:16px}.me-tag{font-size:11px;background:var(--brand-soft);color:var(--brand-deep);padding:1px 7px;border-radius:999px;margin-left:8px}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#18141e80;display:flex;align-items:center;justify-content:center;padding:20px}.modal{width:440px;max-width:100%;max-height:90vh;overflow-y:auto;background:#fff;border-radius:16px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line);font-size:16px;font-weight:700;color:var(--ink)}.modal-x{font-size:22px;color:var(--ink-3);width:28px;height:28px;line-height:1}.modal-body{padding:4px 22px 22px}.modal-acts{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.modal-note{font-size:13px;color:var(--ink-2);background:var(--brand-soft);border-radius:8px;padding:10px 12px;line-height:1.6;margin-top:16px}.field textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:10px 14px;font-size:15px;color:var(--ink);outline:none;resize:vertical;font-family:inherit;transition:border-color .15s}.field textarea:focus{border-color:var(--brand)}.field select{width:100%;height:44px;border:1.5px solid var(--line);border-radius:10px;padding:0 12px;font-size:15px;color:var(--ink);outline:none;background:#fff}.field select:focus{border-color:var(--brand)}.switch-row{display:flex;align-items:center;justify-content:space-between;margin-top:20px}.switch-row span{font-size:14px;color:var(--ink-2)}.switch{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:46px;height:26px;border-radius:999px;background:var(--line);position:relative;cursor:pointer;transition:background .15s;flex-shrink:0}.switch:checked{background:var(--brand-deep)}.switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .15s}.switch:checked:after{transform:translate(20px)}.img-up-btn{display:inline-flex;align-items:center;justify-content:center;width:120px;height:120px;border:1.5px dashed var(--brand);border-radius:10px;color:var(--brand-darker);font-size:13px;cursor:pointer}.img-up-prev{position:relative;width:120px;height:120px;border-radius:10px;overflow:hidden}.img-up-prev img{width:100%;height:100%;object-fit:cover;display:block}.img-up-x{position:absolute;top:0;right:0;width:26px;height:26px;background:#0000008c;color:#fff;font-size:16px;line-height:1;border-bottom-left-radius:8px}.dish-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:16px}.dwc{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}.dwc-img{position:relative;height:160px;background:var(--brand-soft)}.dwc-img img{width:100%;height:100%;object-fit:cover;display:block}.dwc-noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:13px}.dwc-badge{position:absolute;top:8px;right:8px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px}.dwc-badge.on{background:var(--success-soft);color:var(--success)}.dwc-badge.off{background:#0000008c;color:#fff}.dwc-body{padding:12px 14px;flex:1}.dwc-name{font-size:15px;font-weight:700;color:var(--ink)}.dwc-sub{font-size:12px;color:var(--brand-darker);font-weight:600;margin-top:4px}.dwc-desc{font-size:12px;color:var(--ink-2);margin-top:6px;line-height:1.5}.dwc-acts{display:flex;border-top:1px solid var(--line-soft)}.dwc-acts .op{flex:1;margin:0;height:38px;border:none;border-radius:0;border-right:1px solid var(--line-soft)}.dwc-acts .op:last-child{border-right:none}.dwc-acts .op:hover{background:#fcfafe}.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.metric{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center}.metric-n{font-size:32px;font-weight:700;color:var(--brand-darker)}.metric-l{font-size:13px;color:var(--ink-2);margin-top:6px}.stat-card{padding:20px 22px;margin-bottom:18px}.stat-card-h{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:16px}.bar-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.bar-row:last-child{margin-bottom:0}.bar-label{width:56px;font-size:13px;color:var(--ink-2);flex-shrink:0}.bar-track{flex:1;height:14px;background:var(--bg);border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:var(--brand);border-radius:999px;min-width:2px;transition:width .3s}.bar-val{width:40px;text-align:right;font-size:13px;font-weight:600;color:var(--ink);flex-shrink:0}.bar-empty{color:var(--ink-3);font-size:13px}
