:root{--dark-sea: #194141;--ceramic: #00afa8;--ceramic-dark: #00928d;--aqua: #d4e0d4;--puffin: #e65514;--ink: #0f2a2a;--ink-soft: #44605f;--line: #dde3e2;--canvas: #f6f7f6;--paper: #ffffff;--amber: #9a7200;--font-zh: "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", "微軟正黑體", sans-serif;--font-en: "Montserrat", "Segoe UI", system-ui, sans-serif;--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--ease: cubic-bezier(.2, .7, .2, 1);--shadow-1: 0 1px 2px rgba(25, 65, 65, .06), 0 2px 8px rgba(25, 65, 65, .04);--sidebar-w: 212px}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-zh);color:var(--ink);background:var(--canvas);-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{font-family:var(--font-zh);cursor:pointer}.app{display:flex;min-height:100vh;background:var(--canvas)}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--paper);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;transition:transform .2s var(--ease)}.sb-top{padding:16px 14px 12px;border-bottom:1px solid var(--line)}.sb-brand{display:flex;align-items:center;gap:10px}.sb-brand__mark{width:34px;height:34px;border-radius:var(--r-sm);background:var(--ceramic);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}.sb-brand__name{font-family:var(--font-en);font-weight:700;font-size:15px;color:var(--ink);line-height:1.2}.sb-brand__sub{font-size:10.5px;color:var(--ink-soft);margin-top:1px}.nav{padding:8px;flex:1}.sb-group{margin-bottom:2px}.nav-group-head{display:flex;align-items:center;gap:9px;width:100%;padding:9px 10px;border-radius:var(--r-sm);color:var(--ink);font-size:13.5px;font-weight:600;background:none;border:none;text-align:left;-webkit-user-select:none;user-select:none;transition:background .15s}.nav-group-head:hover{background:var(--canvas)}.nav-group-head .chev{margin-left:auto;color:var(--ink-soft);font-size:11px;transition:transform .2s var(--ease)}.nav-sub{display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--r-sm);color:var(--ink-soft);font-size:13.5px;font-weight:500;margin-bottom:2px;transition:background .18s,color .18s}.nav-item:hover{background:var(--canvas);color:var(--ink)}.nav-item.active{background:#00afa817;color:var(--ceramic);font-weight:600}.nav-item--child{padding-left:32px;font-size:13px}.nav-single{font-weight:600;color:var(--ink)}.nav-single.active{color:var(--ceramic)}.sb-footer{padding:10px 8px;border-top:1px solid var(--line)}.sb-user{padding:8px 10px}.sb-user__name{font-size:12.5px;font-weight:600;color:var(--ink)}.sb-user__sub{font-size:10.5px;color:var(--ink-soft);margin-top:1px}.sb-logout{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:var(--r-sm);color:var(--ink-soft);font-size:12.5px;font-weight:500;border:none;background:none;width:100%;transition:.18s}.sb-logout:hover{background:#e655140f;color:var(--puffin)}.main{flex:1;min-width:0;padding:26px 30px}.mtop{display:none}.page-head{display:flex;align-items:center;gap:12px;margin-bottom:22px;flex-wrap:wrap}.page-head h1{font-size:24px;font-weight:700;color:var(--ink)}.page-head .spacer{flex:1}.page-head .muted{font-size:13px}.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;margin-bottom:16px;box-shadow:var(--shadow-1)}.card h2{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:14px}.row{display:flex;flex-wrap:wrap;gap:12px}.row>*{flex:1;min-width:140px}label{display:block;font-size:13px;font-weight:500;color:var(--ink);margin-bottom:6px}input,select,textarea{width:100%;height:40px;padding:0 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--paper);font-size:13.5px;font-family:var(--font-zh);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}textarea{height:auto;padding:9px 12px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--ceramic);box-shadow:0 0 0 4px #00afa824}input::placeholder{color:#9aa8a7}.field{margin-bottom:13px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 18px;border-radius:999px;font-size:13.5px;font-weight:600;border:1px solid var(--ceramic);background:var(--ceramic);color:#fff;white-space:nowrap;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s,color .2s,border-color .2s}.btn:hover{background:var(--ceramic-dark);border-color:var(--ceramic-dark);box-shadow:0 8px 20px #00afa84d;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn-ghost{background:transparent;color:var(--dark-sea);border-color:var(--dark-sea)}.btn-ghost:hover{background:var(--dark-sea);color:#fff;border-color:var(--dark-sea);box-shadow:none}.btn-danger{background:var(--puffin);border-color:var(--puffin);color:#fff}.btn-danger:hover{background:#ce4810;border-color:#ce4810;box-shadow:0 8px 20px #e6551447}.btn-warn{background:transparent;color:var(--ink-soft);border-color:var(--line)}.btn-warn:hover{background:var(--canvas);color:var(--ink);border-color:var(--ink-soft);box-shadow:none}.btn-sm{height:30px;padding:0 13px;font-size:12.5px}.row>.btn,.row>a.btn,.page-head .btn{flex:0 0 auto;min-width:0}.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:9px;padding:12px 18px;border-radius:10px;color:#fff;font-size:14px;font-weight:600;box-shadow:0 8px 28px #0f2a2a47;cursor:pointer;animation:toastIn .2s var(--ease);max-width:360px}.toast.ok{background:var(--ceramic)}.toast.err{background:var(--puffin)}.toast-ic{width:20px;height:20px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.ss{position:relative;width:100%}.ss-control{width:100%;height:40px;padding:0 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--paper);font-size:13.5px;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left}.ss-control.open,.ss-control:focus{border-color:var(--ceramic);box-shadow:0 0 0 4px #00afa824}.ss-control .ss-ph{color:#9aa8a7}.ss-arrow{color:var(--ink-soft);font-size:11px;flex-shrink:0}.ss-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 12px 30px #0f2a2a29;overflow:hidden}.ss-search{height:36px;border:none;border-bottom:1px solid var(--line);border-radius:0}.ss-search:focus{box-shadow:none;border-color:var(--line);border-bottom-color:var(--ceramic)}.ss-list{max-height:240px;overflow-y:auto}.ss-opt{display:block;width:100%;text-align:left;padding:9px 12px;border:none;background:none;font-size:13.5px;color:var(--ink);transition:background .12s}.ss-opt:hover:not(:disabled){background:#00afa814}.ss-opt.hl:not(:disabled){background:#00afa824}.ss-opt.sel{background:#00afa81f;color:var(--ceramic);font-weight:600}.ss-opt:disabled{color:#b6c0bf;cursor:not-allowed}.ss-empty{padding:12px;text-align:center;color:var(--ink-soft);font-size:12.5px}.ac-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 12px 30px #0f2a2a29;overflow:hidden;max-height:280px;overflow-y:auto}.ac-opt{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;text-align:left;padding:11px 14px;border:none;background:none;border-bottom:1px solid var(--line);font-size:14px;color:var(--ink)}.ac-opt:last-child{border-bottom:none}.ac-opt:hover,.ac-opt.hl{background:#00afa81a}.ac-empty{padding:14px;text-align:center;color:var(--ink-soft);font-size:13px}.tbl-wrap,.card .tbl-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{padding:10px 14px;background:var(--canvas);font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}td{padding:12px 14px;font-size:13px;color:var(--ink);border-bottom:1px solid var(--line);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#00afa808}.badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.badge.green{background:#00afa81a;color:var(--ceramic)}.badge.gray{background:#19414112;color:var(--ink-soft)}.badge.red{background:#e655141a;color:var(--puffin)}.badge.warn{background:#d7a0001f;color:var(--amber)}.th-sort{cursor:pointer;-webkit-user-select:none;user-select:none}.th-sort:hover{color:var(--ceramic)}.sort-ind{font-size:10px;color:#aab4b3;margin-left:5px}.sort-ind.on{color:var(--ceramic)}.msg{padding:9px 12px;border-radius:var(--r-sm);font-size:12.5px;margin-bottom:14px}.msg.err{background:#e6551414;color:var(--puffin)}.msg.ok{background:#00afa814;color:var(--ceramic)}.muted{color:var(--ink-soft);font-size:13px}.right{text-align:right}.nowrap{white-space:nowrap}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}.stat{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-1)}.stat .k{color:var(--ink-soft);font-size:12px}.stat .v{font-family:var(--font-en);font-size:30px;font-weight:700;color:var(--ink);margin-top:8px;line-height:1}.stat .v.danger{color:var(--puffin)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f2a2a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--paper);border-radius:var(--r-lg);padding:22px 24px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #0f2a2a2e}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.modal h3{font-size:16px;font-weight:700;color:var(--ink)}.modal-x{width:30px;height:30px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);flex-shrink:0}.modal-x:hover{background:var(--canvas);color:var(--ink)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--paper);padding:16px}.login-card{width:100%;max-width:360px;padding:8px 0}.login-card .lf-logo{display:flex;align-items:center;gap:10px;margin-bottom:30px}.login-card .lf-mark{width:38px;height:38px;border-radius:var(--r-sm);background:var(--ceramic);display:flex;align-items:center;justify-content:center;font-size:20px}.login-card h1{font-size:24px;font-weight:700;color:var(--ink);margin-bottom:4px}.login-card .sub{color:var(--ink-soft);font-size:13px;margin-bottom:26px}.login-card .btn{width:100%;height:46px;border-radius:999px;font-size:15px}.veh-pick{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:-4px 0 4px}.plate-chip{border:1px solid var(--line);background:var(--paper);border-radius:999px;padding:6px 14px;font-size:13.5px;color:var(--ink)}.plate-chip:hover{border-color:var(--ceramic);color:var(--ceramic)}.plate-chip.on{background:var(--ceramic);border-color:var(--ceramic);color:#fff;font-weight:600}.line-item{border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;margin-bottom:10px;background:#fcfdfd}.line-item__main{margin-bottom:10px}.line-item__nums{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.li-qty{width:90px;flex:0 0 auto}.li-price{width:120px;flex:0 0 auto}.li-sub{flex:1;min-width:90px;text-align:right}.li-sub__v{height:40px;display:flex;align-items:center;justify-content:flex-end;font-weight:700;font-size:15px}.line-item__nums .btn-danger{flex:0 0 auto}.cust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.cust-grid .cust-card{margin-bottom:0;height:100%}@media (max-width: 1100px){.cust-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 760px){.cust-grid{grid-template-columns:1fr}}.cust-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.cust-name{font-size:15px;font-weight:700;color:var(--ink)}.veh-list{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 8px}.veh-chip{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;border:1px solid var(--line);border-radius:999px;background:var(--canvas);font-size:13px}.veh-chip__act{display:inline-flex;gap:8px}.linkbtn{background:none;border:none;color:var(--ceramic);font-size:12.5px;font-weight:500;padding:0}.linkbtn:hover{text-decoration:underline}.linkbtn.danger{color:var(--puffin)}.linkbtn.add{margin-top:2px}.rec-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:12px;box-shadow:var(--shadow-1)}.rec-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.rec-date{font-size:12.5px;color:var(--ink-soft)}.rec-who{font-size:16px;font-weight:700;color:var(--ink);margin-top:2px}.rec-right{text-align:right;flex-shrink:0}.rec-amount{font-size:20px;font-weight:700;color:var(--primary-dark);font-family:var(--font-en)}.rec-actions{margin-top:8px;display:flex;gap:6px;justify-content:flex-end}.rec-items{margin-top:12px;padding-top:10px;border-top:1px dashed var(--line)}.rec-item{display:flex;justify-content:space-between;gap:12px;font-size:14px;padding:3px 0}.pagination{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.pg-info{font-size:12.5px;color:var(--ink-soft)}.pg-pages{display:flex;gap:6px;margin-left:auto}.pg-btn{min-width:36px;height:36px;padding:0 8px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);font-size:14px;font-family:var(--font-en);display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s,background .15s}.pg-btn:hover:not(:disabled):not(.active){border-color:var(--ceramic);color:var(--ceramic)}.pg-btn.active{background:var(--ceramic);border-color:var(--ceramic);color:#fff;font-weight:600}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pg-ellipsis{min-width:20px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--ink-soft)}.overlay{display:none}@media (max-width: 820px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:60;transform:translate(-100%);box-shadow:0 0 40px #00000026}.sidebar.open{transform:translate(0)}.overlay.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f2a2a59;z-index:55}.mtop{display:flex;align-items:center;gap:12px;height:54px;padding:0 14px;background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}.mtop .ham{background:none;border:none;font-size:22px;color:var(--dark-sea)}.mtop .t{font-weight:700;color:var(--ink)}.main{padding:16px}.row>*{min-width:100%}}
