:root{--cream:#f5efe5;--paper:#fffdf9;--coffee:#5c3d2e;--brown:#8b644d;--tan:#d7b899;--ink:#2e2824;--muted:#81756d;--green:#6f8067;--shadow:0 12px 35px #4c352016}*{box-sizing:border-box}body{margin:0;background:var(--cream);color:var(--ink);font-family:"Noto Sans TC","Microsoft JhengHei",sans-serif}.topbar{height:72px;padding:0 max(22px,calc((100vw - 1200px)/2));display:flex;align-items:center;justify-content:space-between;background:#fffaf3dd;backdrop-filter:blur(12px);border-bottom:1px solid #dac9b8;position:sticky;top:0;z-index:5}.topbar>div{display:flex;align-items:center;gap:10px}.topbar small{color:var(--muted);font-size:10px;letter-spacing:1.5px}.brand-mark{display:grid;place-items:center;width:38px;height:38px;color:white;background:var(--coffee);border-radius:12px;font-family:serif;font-size:23px}.top-actions{font-size:13px;color:var(--muted)}button{font:inherit;cursor:pointer;border:0}.ghost{padding:9px 13px;background:transparent;border:1px solid #cab6a2;border-radius:12px;color:var(--coffee)}main{max-width:1200px;margin:auto;padding:30px 22px 110px}.view{display:none}.view.active{display:block}.section-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:24px}.eyebrow{margin:0 0 4px;color:var(--brown);font-size:12px;font-weight:700;letter-spacing:2px}.section-head h1{margin:0;font-family:serif;font-size:30px}.legend{font-size:12px;color:var(--muted)}.legend i{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--tan);margin:0 5px 0 12px}.legend i:first-child{background:var(--green)}.table-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.table-card{position:relative;min-height:150px;padding:20px;text-align:left;border-radius:22px;background:var(--paper);box-shadow:var(--shadow);border:1px solid transparent}.table-card.occupied{background:#6f8067;color:white}.table-card .type{font-size:12px;opacity:.7}.table-card strong{display:block;font-family:serif;font-size:27px;margin:8px 0}.table-card .status{position:absolute;right:17px;top:17px;padding:5px 9px;border-radius:20px;background:#eee3d5;color:var(--brown);font-size:11px}.table-card.occupied .status{background:#ffffff24;color:white}.table-card .amount{position:absolute;right:18px;bottom:17px;font-weight:700}.primary{padding:11px 17px;border-radius:12px;background:var(--coffee);color:white}.search input,.dialog-shell input,.dialog-shell select{width:100%;padding:13px 14px;border:1px solid #d9c8b7;border-radius:12px;background:white;font:inherit}.search{max-width:380px;margin-bottom:16px}.member-list{display:grid;gap:12px}.member-card{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-radius:17px;background:var(--paper);box-shadow:var(--shadow)}.member-card p{margin:5px 0 0;color:var(--muted);font-size:13px}.member-balance{text-align:right}.member-balance strong{font-size:22px;color:var(--coffee)}.member-balance button{display:block;margin-top:7px;background:transparent;color:var(--brown);font-size:12px}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.stats article,.panel,.settings-grid article{padding:22px;border-radius:20px;background:var(--paper);box-shadow:var(--shadow)}.stats span{color:var(--muted);font-size:13px}.stats strong{display:block;margin-top:8px;font-family:serif;font-size:30px;color:var(--coffee)}.panel{margin-top:17px}.panel h2{font-size:16px;margin:0 0 15px}.pay-row,.transaction{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid #eee4d9}.transactions .empty,#cart .empty{color:var(--muted);text-align:center;padding:25px}.settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.settings-grid p{color:var(--muted);font-size:13px;min-height:38px}.settings-grid button{color:#a3968b;background:#eee8e1;padding:9px;border-radius:9px}.bottom-nav{position:fixed;left:50%;bottom:15px;transform:translateX(-50%);z-index:6;display:flex;gap:5px;padding:7px;background:#fffdf9eF;border:1px solid #dbcaba;border-radius:20px;box-shadow:0 12px 40px #432d2038;backdrop-filter:blur(10px)}.bottom-nav button{min-width:85px;padding:9px 15px;border-radius:14px;background:transparent;color:var(--muted);font-size:12px}.bottom-nav span{display:block;font-size:19px;margin-bottom:2px}.bottom-nav button.active{background:var(--coffee);color:white}dialog{width:min(1050px,94vw);padding:0;border:0;border-radius:24px;background:var(--paper);box-shadow:0 30px 80px #28170e66}dialog::backdrop{background:#33251d88;backdrop-filter:blur(3px)}.dialog-shell{padding:24px}.dialog-shell header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eadfd4;padding-bottom:16px}.dialog-shell h2{margin:0}.close{font-size:28px;background:transparent;color:var(--muted)}.order-body{display:grid;grid-template-columns:1fr 320px;gap:24px;margin-top:20px}.order-body aside{border-left:1px solid #e8ddd2;padding-left:22px}.chips{display:flex;gap:8px;overflow:auto;margin-bottom:15px}.chips button{white-space:nowrap;padding:8px 13px;border-radius:18px;background:#eee3d7;color:var(--brown)}.chips button.active{background:var(--coffee);color:#fff}.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.menu-item{min-height:95px;padding:14px;text-align:left;border:1px solid #e1d3c5;background:white;border-radius:15px}.menu-item b{display:block}.menu-item span{display:block;color:var(--brown);margin-top:15px}.cart-item{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid #eee3d7}.cart-item button{width:26px;height:26px;border-radius:50%}.cart-total{display:flex;justify-content:space-between;font-size:20px;padding:18px 0}.wide{width:100%}.compact{max-width:500px;margin:auto;display:grid;gap:15px}.compact label{display:grid;gap:6px;color:var(--muted);font-size:13px}.checkout-total{padding:20px;background:#efe5d8;border-radius:15px;display:flex;justify-content:space-between}.checkout-total strong{font-size:24px}.payment-options{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}.payment-options button{padding:14px 5px;border-radius:12px;background:#eaddcf;color:var(--coffee)}#toast{position:fixed;left:50%;bottom:105px;transform:translate(-50%,20px);padding:11px 17px;border-radius:12px;background:#2e2824;color:white;opacity:0;pointer-events:none;transition:.25s;z-index:20}#toast.show{opacity:1;transform:translate(-50%,0)}
@media(max-width:700px){.topbar small,#clock,.business-hours{display:none}main{padding:22px 14px 100px}.table-grid{grid-template-columns:repeat(2,1fr);gap:11px}.table-card{min-height:130px;padding:15px}.stats,.settings-grid{grid-template-columns:1fr}.bottom-nav{bottom:8px;width:calc(100% - 18px);justify-content:space-around}.bottom-nav button{min-width:0;flex:1;padding:8px 4px}.order-body{grid-template-columns:1fr}.order-body aside{border-left:0;border-top:1px solid #e8ddd2;padding:15px 0 0}.menu-grid{grid-template-columns:repeat(2,1fr)}dialog{width:96vw;max-height:92vh;overflow:auto}.dialog-shell{padding:17px}.member-card{padding:15px}.section-head h1{font-size:27px}}
.settings-grid .manage-btn{color:white;background:var(--coffee)}.report-controls{display:flex;justify-content:space-between;align-items:center;margin:-10px 0 18px}.report-controls .chips{margin:0}.report-controls input{padding:9px 12px;border:1px solid #d9c8b7;border-radius:11px;background:white;color:var(--coffee);font:inherit}.admin-toolbar{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:18px 0}.admin-toolbar p{color:var(--muted);font-size:13px}.admin-list{display:grid;gap:9px;max-height:58vh;overflow:auto}.admin-row{display:grid;grid-template-columns:1fr 140px 110px 160px;gap:12px;align-items:center;padding:13px 15px;border:1px solid #e5d8cb;border-radius:14px}.admin-row.off{opacity:.55}.admin-row small{color:var(--muted)}.admin-actions{display:flex;gap:6px}.admin-actions button{padding:7px 10px;border-radius:9px;background:#eee3d7;color:var(--coffee)}.admin-actions .danger{color:#8d4035}.item-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid #eee4d9}@media(max-width:700px){.admin-row{grid-template-columns:1fr auto}.admin-row .admin-price{display:none}.admin-actions{grid-column:1/-1}.admin-toolbar{align-items:flex-start}.report-controls{align-items:flex-end}}
.report-dates{display:flex;gap:8px}.report-dates input:disabled{opacity:.55;cursor:not-allowed}
.wide-dialog{width:min(1180px,96vw)}.cost-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding-top:18px}.cost-stats article{padding:17px;border-radius:16px;background:#f2e8dc}.cost-stats span,.cost-stats small{display:block;color:var(--muted);font-size:12px}.cost-stats strong{display:block;margin:7px 0;font-size:23px;color:var(--coffee)}.table-wrap{overflow:auto;border:1px solid #e4d7ca;border-radius:15px}.cost-table{width:100%;min-width:940px;border-collapse:collapse;background:white;font-size:13px}.cost-table th{padding:11px 12px;text-align:left;color:var(--muted);background:#f5eee6;white-space:nowrap}.cost-table td{padding:12px;border-top:1px solid #eee4d9;white-space:nowrap}.cost-table td:first-child{white-space:normal;font-weight:700}.status-pill{display:inline-block;padding:5px 9px;border-radius:15px;background:#e4eddf;color:#53654d;font-size:11px}.status-pill.low{background:#f5dfd4;color:#954d37}.status-pill.warn{background:#f4e9c9;color:#866a24}.table-actions{display:flex;gap:5px}.table-actions button{padding:6px 8px;border-radius:8px;background:#eee3d7;color:var(--coffee)}.equipment-head{margin-top:12px}.form-pair{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:700px){.cost-stats{grid-template-columns:repeat(2,1fr)}.cost-stats strong{font-size:19px}.wide-dialog .dialog-shell{min-width:0}.admin-toolbar{gap:8px}.admin-toolbar .primary{white-space:nowrap}.form-pair{grid-template-columns:1fr}}
.permission-note{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:18px;padding:14px 16px;border-radius:14px;background:#f2e8dc}.permission-note span{padding:6px 10px;border-radius:12px;background:white;color:var(--muted);font-size:12px}.employee-list{display:grid;gap:10px}.employee-row{display:grid;grid-template-columns:1fr 100px 100px 100px 170px;gap:12px;align-items:center;padding:15px;border:1px solid #e4d7ca;border-radius:14px;background:white}.employee-row.off{opacity:.55}.employee-row small{color:var(--muted)}@media(max-width:700px){.employee-row{grid-template-columns:1fr auto}.employee-row>span:nth-child(3),.employee-row>span:nth-child(4){display:none}.employee-row .admin-actions{grid-column:1/-1}}
.picker-members{display:grid;gap:8px;max-height:330px;overflow:auto}.picker-member{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:1px solid #e2d4c6;border-radius:13px;background:white;text-align:left}.picker-member b,.picker-member small{display:block}.picker-member small{margin-top:3px;color:var(--muted)}.picker-member strong{color:var(--coffee)}.linked-member{padding:10px 12px;margin-bottom:10px;border-radius:12px;background:#eef1e9;color:var(--green);font-size:13px}.redeem-tag{display:inline-block;margin-left:5px;padding:2px 6px;border-radius:8px;background:#e8ddd0;color:var(--brown);font-size:10px}
.linked-member{display:flex;justify-content:space-between;align-items:center;gap:8px}.member-link-actions{display:flex;gap:5px}.member-link-actions button{padding:5px 7px;border-radius:8px;background:white;color:var(--coffee);font-size:11px}.cart-item{grid-template-columns:1fr auto auto}.qty-control{display:flex;align-items:center;gap:7px}.qty-control button{width:28px;height:28px;border-radius:8px;background:#eee3d7;color:var(--coffee)}.qty-control strong{min-width:18px;text-align:center}.topup-tag{display:inline-block;margin-left:5px;padding:2px 6px;border-radius:8px;background:#e1eadc;color:#52694c;font-size:10px}@media(max-width:700px){.linked-member{align-items:flex-start;flex-direction:column}.cart-item{grid-template-columns:1fr auto}.cart-item>strong{grid-column:1}.qty-control{grid-column:2;grid-row:1/3}}
.linked-member small{display:block;margin-top:3px;color:var(--green)}
.member-balance .member-expiry{display:block;margin-top:8px;font-size:14px;color:var(--green)}
.hourly-chart{grid-template-columns:repeat(11,1fr)}
.app-locked>.topbar,.app-locked>main,.app-locked>.bottom-nav{display:none}.login-screen{min-height:100vh;display:grid;grid-template-columns:1.15fr .85fr;background:var(--cream)}body:not(.app-locked) .login-screen{display:none}.login-visual{display:flex;flex-direction:column;justify-content:center;padding:8vw;background:linear-gradient(145deg,#4a3025,#74503b);color:white;position:relative;overflow:hidden}.login-visual:after{content:"";position:absolute;width:420px;height:420px;border:1px solid #ffffff1f;border-radius:50%;right:-130px;bottom:-150px;box-shadow:0 0 0 70px #ffffff08,0 0 0 140px #ffffff05}.login-monogram{display:grid;place-items:center;width:68px;height:68px;border:1px solid #ffffff55;border-radius:20px;font-family:serif;font-size:38px}.login-visual p{letter-spacing:4px;font-size:11px;color:#e3cdbb}.login-visual h1{font-family:serif;font-size:clamp(32px,4vw,58px);line-height:1.35;margin:42px 0 30px}.login-visual small{letter-spacing:2px;color:#d2bca9}.login-card{align-self:center;width:min(390px,82%);margin:auto;padding:34px;border-radius:24px;background:#fffdf9;box-shadow:0 25px 70px #4c352028}.login-card h2{margin:4px 0 8px;font-family:serif;font-size:28px}.login-card>p:not(.eyebrow){color:var(--muted);font-size:13px;margin-bottom:25px}.login-card label{display:grid;gap:7px;margin:15px 0;color:var(--muted);font-size:13px}.login-card input,.login-card select{width:100%;padding:13px 14px;border:1px solid #d9c8b7;border-radius:12px;background:white;font:inherit}.login-card>small{display:block;margin-top:15px;text-align:center;color:var(--muted)}.login-error{min-height:18px!important;margin:5px 0!important;color:#b4372b!important}@media(max-width:760px){.login-screen{grid-template-columns:1fr}.login-visual{min-height:270px;padding:35px}.login-visual h1{font-size:30px;margin:20px 0 10px}.login-card{margin:35px auto}}
@media(max-width:1100px){button,.ghost,.primary,input,select{min-height:44px}.topbar{padding-left:18px;padding-right:18px}.table-grid{grid-template-columns:repeat(2,1fr)}.settings-grid{grid-template-columns:repeat(2,1fr)}.order-body{grid-template-columns:minmax(0,1fr) 290px}.menu-grid{grid-template-columns:repeat(2,1fr)}dialog{max-height:90dvh;overflow:auto}.bottom-nav{bottom:max(10px,env(safe-area-inset-bottom));touch-action:manipulation}.bottom-nav button{min-height:54px}.chips button{min-height:40px}.table-card{touch-action:manipulation}.login-card input,.login-card select,.dialog-shell input,.dialog-shell select{font-size:16px}}
@media(max-width:700px){main{padding-bottom:calc(105px + env(safe-area-inset-bottom))}.topbar{height:64px}.order-body{grid-template-columns:1fr}.settings-grid{grid-template-columns:1fr}.payment-options button{min-height:52px}.login-screen{min-height:100dvh}.login-card{width:calc(100% - 28px);padding:25px}.login-visual{min-height:230px}.login-visual small{display:none}}
.member-alert-summary{display:none;margin-bottom:14px;padding:14px 16px;border:1px solid #e7b9ad;border-radius:14px;background:#fff0ec;color:#a33f32;font-size:13px}.member-alert-summary.show{display:block}.member-alert-summary b{display:block;margin-bottom:5px}.member-alert{color:#b4372b!important}.member-warning{margin-top:7px!important;color:#b4372b!important;font-weight:700}.linked-member small.member-alert{color:#b4372b}
.panel-title-row{display:flex;justify-content:space-between;align-items:center}.panel-title-row h2{margin:0}.profit-grid{display:grid;grid-template-columns:repeat(9,auto);gap:12px;align-items:center;margin-top:18px}.profit-grid div{padding:13px;border-radius:13px;background:#f3ece4}.profit-grid span{display:block;color:var(--muted);font-size:11px}.profit-grid strong{display:block;margin-top:5px;font-size:19px;color:var(--coffee)}.profit-grid i{color:var(--muted);font-style:normal}.profit-grid .net-profit{background:var(--coffee);color:white}.profit-grid .net-profit span,.profit-grid .net-profit strong{color:white}.expense-breakdown{display:flex;gap:14px;flex-wrap:wrap;margin-top:13px;color:var(--muted);font-size:12px}.master-label{display:block;margin-top:3px;color:var(--brown);font-size:11px}@media(max-width:850px){.profit-grid{grid-template-columns:1fr}.profit-grid i{text-align:center}.profit-grid div{text-align:center}}
.transaction{align-items:center;gap:10px}.transaction-main{flex:1}.detail-btn{padding:6px 9px;border-radius:8px;background:#eee3d7;color:var(--coffee);font-size:11px}.order-detail-meta{padding:12px;border-radius:12px;background:#f3ece4;color:var(--muted);font-size:13px}.order-detail-item{padding:12px 0;border-bottom:1px solid #eadfd4}.order-detail-item>div{display:flex;justify-content:space-between}.order-detail-item small{display:block;margin-top:5px;color:var(--brown)}.master-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.master-stat{padding:15px;border-radius:14px;background:#f3ece4}.master-stat b,.master-stat span{display:block}.master-stat span{margin-top:6px;color:var(--muted);font-size:12px}.master-stat strong{display:block;margin-top:7px;color:var(--coffee)}@media(max-width:700px){.master-stats{grid-template-columns:1fr}.transaction{flex-wrap:wrap}.detail-btn{width:100%}}
.member-card{flex-wrap:wrap}.member-history-toggle{margin-top:8px;padding:6px 9px;border-radius:9px;background:#eee3d7;color:var(--coffee);font-size:11px}.member-history{display:none;flex-basis:100%;margin-top:12px;padding-top:10px;border-top:1px solid #eadfd4}.member-history.open{display:block}.member-history-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid #f0e7dd;font-size:13px}.member-history-row small{display:block;margin-top:3px;color:var(--muted)}
.shareholder-badge{display:inline-block;margin-left:6px;padding:3px 7px;border-radius:9px;background:#e7d6b8;color:#75522e;font-size:10px}.discount-note{display:block;margin-top:4px;color:#9a6635;font-size:11px}.quota-ok{color:var(--green)}.quota-low{color:#b4372b}
.ops-dashboard{margin-bottom:24px}.ops-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.ops-card{padding:18px;border-radius:18px;background:var(--paper);box-shadow:var(--shadow);opacity:0;transform:translateY(14px);animation:cardIn .55s cubic-bezier(.2,.8,.2,1) forwards}.ops-card:nth-child(2){animation-delay:.08s}.ops-card:nth-child(3){animation-delay:.16s}.ops-card:nth-child(4){animation-delay:.24s}.ops-card span,.ops-card small{display:block;color:var(--muted);font-size:12px}.ops-card strong{display:block;margin:7px 0;font-family:serif;font-size:27px;color:var(--coffee)}.mini-progress{height:6px;margin-top:12px;border-radius:9px;background:#eadfd4;overflow:hidden}.mini-progress i{display:block;width:0;height:100%;border-radius:9px;background:var(--green);transition:width .8s cubic-bezier(.2,.8,.2,1)}.hourly-panel{margin-top:13px;padding:20px;border-radius:20px;background:var(--paper);box-shadow:var(--shadow);animation:panelIn .65s .2s both}.hourly-panel h2{margin:0;font-size:17px}.hourly-panel .panel-title-row>span{color:var(--muted);font-size:12px}.hourly-chart{display:grid;grid-template-columns:repeat(16,1fr);align-items:end;gap:7px;height:150px;margin-top:18px;padding-top:10px;border-bottom:1px solid #dfd2c6}.hour-bar{height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:5px}.hour-bar i{display:block;width:100%;max-width:25px;height:var(--h);min-height:3px;border-radius:7px 7px 2px 2px;background:linear-gradient(180deg,var(--tan),var(--coffee));transform:scaleY(0);transform-origin:bottom;animation:barGrow .75s cubic-bezier(.2,.8,.2,1) forwards;animation-delay:var(--delay)}.hour-bar span{font-size:9px;color:var(--muted)}@keyframes cardIn{to{opacity:1;transform:none}}@keyframes panelIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes barGrow{to{transform:scaleY(1)}}@media(max-width:700px){.ops-cards{grid-template-columns:repeat(2,1fr)}.ops-card strong{font-size:22px}.hourly-chart{gap:3px;overflow:hidden}.hour-bar span{font-size:8px}}@media(prefers-reduced-motion:reduce){.ops-card,.hourly-panel,.hour-bar i{animation:none;opacity:1;transform:none}.mini-progress i{transition:none}}
.cloud-status{display:block;margin-top:.45rem;color:var(--muted)}
.cloud-status[data-state="online"]{color:#3f7d5d}
.cloud-status[data-state="error"]{color:#b74747}
