.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:440px;padding:50px 40px;animation:slideUp .5s ease-out}.login-header{text-align:center;margin-bottom:40px}.login-icon{font-size:64px;margin-bottom:20px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1{font-size:32px;font-weight:700;color:#2d3748;margin:0 0 10px}.login-header p{font-size:16px;color:#718096;margin:0}.login-form{margin-bottom:30px}.form-group{margin-bottom:24px}.form-group label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#4a5568;margin-bottom:8px}.label-icon{font-size:18px}.password-input-wrapper{position:relative;width:100%}.password-input-wrapper input{width:100%;padding:14px 50px 14px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:20px;padding:4px 8px;opacity:.6;transition:opacity .2s ease}.password-toggle:hover{opacity:1}.form-group input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.form-group input:focus,.password-input-wrapper input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-error{background:#fee;border:2px solid #fcc;border-radius:12px;padding:14px 16px;color:#c53030;font-size:14px;font-weight:600;margin-bottom:20px;animation:shake .5s}.login-button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 15px #667eea66}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.login-button:active{transform:translateY(0);box-shadow:0 2px 10px #667eea4d}.login-arrow{font-size:24px;transition:transform .3s ease}.login-button:hover .login-arrow{transform:translate(5px)}.login-footer{text-align:center;padding-top:20px;border-top:1px solid #e2e8f0}.login-hint{font-size:13px;color:#a0aec0;margin:0}@media (max-width: 768px){.login-box{padding:40px 30px}.login-header h1{font-size:28px}.login-icon{font-size:56px}}.print-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:3000;animation:fadeIn .2s ease}.print-modal{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;animation:slideUp .3s ease}.print-modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center}.print-modal-header h3{margin:0;font-size:20px}.print-modal-close{width:32px;height:32px;border-radius:50%;border:2px solid white;background:transparent;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.print-modal-close:hover{background:#fff;color:#667eea;transform:rotate(90deg)}.print-preview{flex:1;overflow-y:auto;padding:30px;background:#f5f5f5;display:flex;justify-content:center;align-items:flex-start}.print-bill{background:#fff;padding:20px;width:100%;font-family:Courier New,monospace;box-shadow:0 4px 12px #0000001a;border-radius:8px}.kitchen-bill{border:2px dashed #667eea}.kitchen-bill .bill-header h2{margin:0 0 10px;text-align:center;font-size:18px;color:#333}.bill-time,.bill-code,.bill-tab{text-align:center;font-size:12px;color:#666;margin:4px 0}.bill-tab{font-weight:700;color:#667eea;font-size:14px}.bill-divider{margin:12px 0;color:#ccc;text-align:center;font-size:10px;letter-spacing:-1px}.kitchen-item{margin:12px 0;padding:10px;background:#f9f9f9;border-left:4px solid #667eea;border-radius:4px}.item-header{display:flex;gap:10px;align-items:center;font-weight:700}.item-qty{background:#667eea;color:#fff;padding:4px 10px;border-radius:4px;font-size:14px;min-width:40px;text-align:center}.item-name{flex:1;font-size:16px;color:#333}.item-note{margin-top:8px;padding:6px 10px;background:#fff;border-radius:4px;font-size:12px;color:#667eea;border:1px dashed #667eea}.customer-bill{border:2px solid #333}.customer-bill .bill-header h2{margin:0 0 8px;text-align:center;font-size:20px;color:#333}.cafe-info{text-align:center;font-size:11px;color:#666;margin:2px 0}.bill-info{font-size:12px;color:#333}.bill-info>div{margin:4px 0}.item-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:6px 0}.item-row.header{font-weight:700;border-bottom:1px solid #ccc;margin-bottom:8px}.col-name{flex:2}.col-qty{flex:0 0 50px;text-align:center}.col-price{flex:0 0 100px;text-align:right}.customer-item{margin:8px 0}.item-note-customer{font-size:10px;color:#666;margin-top:4px;padding-left:10px;font-style:italic}.bill-total{margin:12px 0}.total-row{display:flex;justify-content:space-between;font-size:13px;margin:6px 0}.total-row.voucher-row{color:#10b981;font-weight:600}.total-row.grand{font-size:16px;font-weight:700;margin-top:10px;padding-top:10px;border-top:2px solid #333}.bill-footer{margin-top:12px;text-align:center}.total-items{font-weight:700;font-size:14px;text-align:center;color:#667eea}.footer-text{font-size:12px;color:#666;margin:4px 0}.print-modal-actions{padding:20px;border-top:1px solid #e0e0e0;display:flex;gap:12px}.btn-print,.btn-close-print{flex:1;padding:14px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-close-print{background:#f0f0f0;color:#666}.btn-close-print:hover{background:#e0e0e0}@media print{body{margin:0;padding:0}.print-modal-overlay,.print-modal-header,.print-modal-actions,.print-preview{display:block!important;background:none!important;box-shadow:none!important;padding:0!important;margin:0!important}.print-bill{max-width:100%;box-shadow:none;border:none;page-break-inside:avoid}.no-print{display:none!important}}.print-label-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .2s ease}.print-label-modal{background:#fff;border-radius:16px;padding:24px;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.print-label-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.print-label-header h3{font-size:20px;color:#333;margin:0}.btn-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.btn-close:hover{background:#f0f0f0;color:#333}.print-label-preview{border:2px dashed #ddd;border-radius:12px;padding:20px;margin-bottom:20px;background:#fafafa;min-height:150px;display:flex;align-items:center;justify-content:center}.label-container{text-align:center;max-width:100%}.item-name{font-size:18px;font-weight:700;color:#333;margin-bottom:8px;word-wrap:break-word}.item-note{font-size:14px;color:#666;margin-bottom:12px;word-wrap:break-word;line-height:1.4}.item-quantity{font-size:20px;font-weight:700;color:#667eea;margin-top:8px}.print-label-actions{display:flex;gap:12px}.btn-cancel,.btn-print{flex:1;padding:14px 20px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel:hover{background:#e0e0e0;transform:translateY(-2px)}.btn-print{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.btn-print:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media print{.print-label-header,.print-label-actions{display:none!important}.print-label-preview{border:none;background:#fff;padding:0}}.blocked-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#434343,#000);padding:20px}.blocked-content{background:#fff;border-radius:24px;padding:60px 40px;text-align:center;max-width:500px;box-shadow:0 20px 60px #00000080}.blocked-icon{font-size:80px;margin-bottom:20px;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.blocked-content h1{font-size:32px;color:#e74c3c;margin-bottom:16px}.blocked-content p{font-size:16px;color:#666;margin-bottom:12px;line-height:1.6}.blocked-warning{background:#fff3cd;border:2px solid #ffc107;border-radius:8px;padding:12px;color:#856404;font-weight:600;margin:20px 0}.blocked-actions{display:flex;gap:12px;margin-top:30px;justify-content:center}.btn-close-tab,.btn-retry{padding:14px 28px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;border:none;transition:all .3s ease}.btn-close-tab{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.btn-close-tab:hover{transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c66}.btn-retry{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.btn-retry:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.menu-container{min-height:100vh;padding-top:140px;padding-bottom:120px;background:linear-gradient(135deg,#667eea,#764ba2);transition:padding-right .3s ease}.menu-container.sidebar-open{padding-right:420px}.sync-warning{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:300;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.sync-warning-content{background:linear-gradient(135deg,#f96,#ff5e62);color:#fff;padding:12px 20px;border-radius:12px;box-shadow:0 4px 20px #ff5e6266;display:flex;align-items:center;gap:12px;min-width:400px;max-width:600px}.warning-icon{font-size:24px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.warning-text{flex:1;font-size:14px;font-weight:600}.warning-close{background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.warning-close:hover{background:#ffffff4d;transform:scale(1.1)}.menu-header{position:fixed;top:0;left:0;right:0;background:#fff;padding:8px;text-align:center;z-index:200}.menu-header h1{color:#333;font-size:28px;margin-bottom:8px}.menu-header p{color:#666;font-size:14px}.header-actions{position:fixed;top:20px;right:20px;display:flex;gap:10px;z-index:201}.cms-btn,.display-btn,.history-btn,.logout-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #667eea4d;white-space:nowrap}.cms-btn{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 2px 10px #f093fb4d}.display-btn{background:linear-gradient(135deg,#48c6ef,#6f86d6);box-shadow:0 2px 10px #48c6ef4d}.logout-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 2px 10px #e74c3c4d}.cms-btn:hover,.display-btn:hover,.history-btn:hover,.logout-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.cms-btn:hover{box-shadow:0 4px 15px #f093fb66}.display-btn:hover{box-shadow:0 4px 15px #48c6ef66}.logout-btn:hover{box-shadow:0 4px 15px #e74c3c66}.tabs-container{position:fixed;top:72px;left:0;right:0;display:flex;gap:8px;padding:12px 20px 2px;background:#fff;border-bottom:2px solid #f0f0f0;overflow-x:auto;overflow-y:visible;white-space:nowrap;z-index:199;transition:right .3s ease}.tabs-container::-webkit-scrollbar{height:4px}.tab{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f5f5f5;border:2px solid transparent;border-radius:8px 8px 0 0;cursor:pointer;transition:all .2s ease;min-width:120px;font-size:14px;font-weight:500;color:#666}.tab:hover{background:#e8e8e8}.tab.active{background:#fff;border-color:#667eea;border-bottom-color:#fff;color:#667eea;font-weight:600;margin-bottom:-2px}.tab.displaying{position:relative;background:linear-gradient(135deg,#11998e1a,#38ef7d1a);border-color:#11998e;box-shadow:0 0 0 2px #11998e33}.tab.displaying.active{background:linear-gradient(135deg,#11998e26,#38ef7d26);border-color:#11998e;border-bottom-color:#fff}.display-indicator{display:inline-block;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.tab-name{flex:1}.tab-close{width:20px;height:20px;border-radius:50%;border:none;background:#0000001a;color:#666;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.tab-close:hover{background:#e74c3c;color:#fff}.tab-new{padding:10px 16px;background:transparent;border:2px dashed #ccc;border-radius:8px 8px 0 0;color:#999;font-size:13px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tab-new:hover{border-color:#667eea;color:#667eea;background:#667eea0d}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:20px;max-width:1200px;margin:0 auto}.menu-item{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;display:flex;flex-direction:column}.menu-item.selected{border:2px solid #667eea;box-shadow:0 4px 16px #667eea4d;padding:15px}.item-info{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #f0f0f0}.item-info h3{color:#333;font-size:18px;margin-bottom:6px}.item-note{color:#667eea;font-size:13px;margin:6px 0;font-style:italic;background:#667eea1a;padding:4px 8px;border-radius:4px;display:inline-block}.item-price{color:#e74c3c;font-size:16px;font-weight:600}.quantity-display{display:flex;justify-content:space-between;align-items:center;padding:12px;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-radius:8px;margin:12px 0}.quantity-label{color:#666;font-size:14px;font-weight:500}.quantity-value{color:#667eea;font-size:24px;font-weight:700}.total-qty-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 12px;border-radius:16px;font-size:13px;font-weight:700;display:inline-block;margin-top:8px;letter-spacing:.5px;box-shadow:0 2px 8px #667eea4d}.note-btn-main{width:100%;padding:12px;background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.note-btn-main:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.quantity-controls.small{gap:8px;margin-top:8px}.qty-btn{width:36px;height:36px;border-radius:50%;border:2px solid #667eea;background:#fff;color:#667eea;font-size:20px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.qty-btn.small{width:28px;height:28px;font-size:16px;border-width:1.5px}.qty-btn:hover:not(:disabled){background:#667eea;color:#fff;transform:scale(1.1)}.qty-btn:disabled{opacity:.3;cursor:not-allowed}.quantity{font-size:20px;font-weight:700;color:#333;min-width:30px;text-align:center}.note-btn{width:100%;margin-top:12px;padding:10px 12px;background:#fff;border:2px dashed #667eea;border-radius:8px;color:#667eea;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.note-btn:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-style:solid;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.order-summary{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(to top,#fffffffa,#fffffff2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 -4px 20px #0000001a;padding:20px;z-index:100;border-top:2px solid rgba(102,126,234,.1)}.summary-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:24px}.summary-info{flex:1;display:flex;flex-direction:column;gap:4px}.summary-items{color:#666;font-size:14px;margin-bottom:0;font-weight:500}.summary-total{color:#333;font-size:24px;font-weight:700;margin-bottom:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.create-qr-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 40px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #667eea66;white-space:nowrap;letter-spacing:.5px}.create-qr-btn:hover{transform:translateY(-3px);box-shadow:0 8px 30px #667eea99}.create-qr-btn:active{transform:translateY(-1px);box-shadow:0 4px 20px #667eea66}.voucher-section{margin:12px 0;width:100%}.voucher-section-modal{margin:16px 0;width:100%;padding:16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;border:2px solid #0ea5e9}.voucher-input-group{display:flex;gap:8px;width:100%}.voucher-input{flex:1;padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:600;text-transform:uppercase;transition:all .2s ease;background:#fff}.voucher-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.voucher-input:disabled{background:#f7fafc;cursor:not-allowed}.voucher-btn{padding:10px 20px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.voucher-btn.apply{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.voucher-btn.apply:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.voucher-btn.apply:disabled{opacity:.5;cursor:not-allowed}.voucher-btn.remove{background:#fee2e2;color:#991b1b}.voucher-btn.remove:hover{background:#ef4444;color:#fff}.voucher-error{color:#ef4444;font-size:12px;margin:6px 0 0;font-weight:500}.voucher-success{color:#10b981;font-size:13px;margin:6px 0 0;font-weight:600}.summary-breakdown{margin:8px 0;padding:12px;background:#f7fafc;border-radius:8px;display:flex;flex-direction:column;gap:6px}.breakdown-row{display:flex;justify-content:space-between;font-size:14px;color:#4a5568}.breakdown-row.discount{color:#10b981;font-weight:600}.qr-sidebar{position:fixed;top:0;right:0;width:400px;height:100vh;background:#fff;box-shadow:-4px 0 20px #00000026;z-index:1000;display:flex;flex-direction:column;animation:slideIn .3s ease;overflow:hidden}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:2px solid #f0f0f0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sidebar-header h3{margin:0;font-size:18px}.sidebar-close{width:32px;height:32px;border-radius:50%;border:2px solid white;background:transparent;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-close:hover{background:#fff;color:#667eea}.sidebar-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px}.sidebar-qr{background:#f8f8f8;border-radius:12px;padding:16px;margin-bottom:20px;display:flex;justify-content:center}.sidebar-qr-image{width:100%;max-width:300px;border-radius:8px}.sidebar-info{margin-bottom:20px}.info-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f0f0f0}.info-row.highlight{background:linear-gradient(135deg,#667eea1a,#764ba21a);padding:12px;border-radius:8px;margin:12px 0;border:none}.info-label{color:#666;font-size:14px}.info-value{color:#333;font-weight:600;font-size:14px}.info-value.amount{color:#e74c3c;font-size:20px}.sidebar-items{margin-bottom:20px}.sidebar-items h4{color:#333;font-size:15px;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #667eea}.sidebar-item{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid #f0f0f0;font-size:14px}.item-details{flex:1;display:flex;flex-direction:column;gap:4px}.item-name{color:#333;font-weight:600}.item-note-small{color:#667eea;font-size:12px;font-style:italic}.item-price{color:#666;font-weight:600;white-space:nowrap;margin-left:12px}.sidebar-actions{display:flex;flex-direction:column;gap:12px;padding:20px;background:#fff;border-top:2px solid #f0f0f0;box-shadow:0 -4px 10px #0000000d;flex-shrink:0}.sidebar-main-actions{display:flex;gap:8px}.btn-success,.btn-cancel,.btn-display{flex:1;padding:14px 8px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;text-align:center;text-decoration:none;display:block;white-space:nowrap}.btn-success{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;box-shadow:0 4px 15px #11998e4d}.btn-success:hover{transform:translateY(-2px);box-shadow:0 6px 20px #11998e66}.btn-cancel{background:#f0f0f0;color:#666}.btn-cancel:hover{background:#e74c3c;color:#fff}.btn-display{background:#667eea;color:#fff}.btn-display:hover{background:#764ba2}.print-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;padding-top:12px;border-top:1px dashed #e0e0e0}.btn-print{padding:12px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;text-align:center}.btn-print.kitchen{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 4px 15px #f093fb4d;padding:12px}.btn-print.kitchen:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f093fb66}.btn-print.customer{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;box-shadow:0 4px 15px #4facfe4d}.btn-print.customer:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4facfe66}.note-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.note-modal{background:#fff;border-radius:20px;width:90%;max-width:520px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.note-modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center}.note-modal-header h3{margin:0;font-size:20px}.note-modal-close{width:32px;height:32px;border-radius:50%;border:2px solid white;background:transparent;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.note-modal-close:hover{background:#fff;color:#667eea;transform:rotate(90deg)}.note-modal-content{flex:1;overflow-y:auto;padding:20px}.variants-list{margin-bottom:20px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.variants-list h4{color:#333;font-size:14px;margin-bottom:12px;font-weight:600}.variant-row{display:flex;align-items:center;gap:8px;padding:10px;background:#f8f9fa;border-radius:8px;margin-bottom:8px;border:1px solid #e9ecef}.variant-info{flex:1;display:flex;justify-content:space-between;align-items:center;gap:12px}.variant-note-text{flex:1;color:#495057;font-size:13px;font-weight:500}.variant-qty-controls{display:flex;align-items:center;gap:8px}.qty-btn-small{width:28px;height:28px;border-radius:6px;border:1.5px solid #667eea;background:#fff;color:#667eea;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.qty-btn-small:hover{background:#667eea;color:#fff}.qty-btn-small:active{transform:scale(.95)}.qty-text{min-width:30px;text-align:center;font-weight:700;color:#333;font-size:15px}.variant-actions{display:flex;gap:8px}.print-label-btn{width:32px;height:32px;border-radius:6px;border:none;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #f5576c4d}.print-label-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #f5576c66}.edit-variant-btn{width:32px;height:32px;border-radius:6px;border:none;background:#667eea;color:#fff;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.edit-variant-btn:hover{background:#5568d3;transform:scale(1.05)}.edit-variant-btn.active{background:#e74c3c}.edit-form-inline{margin-top:12px;padding:16px;background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.note-option-inline{margin-bottom:16px}.note-option-inline label{display:block;color:#495057;font-weight:600;margin-bottom:8px;font-size:13px}.note-choices-inline{display:flex;gap:6px;flex-wrap:wrap}.note-choice-small{flex:1;min-width:50px;padding:8px 12px;border:1.5px solid #dee2e6;background:#fff;border-radius:6px;color:#495057;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.note-choice-small:hover{border-color:#667eea;background:#667eea0d}.note-choice-small.active{border-color:#667eea;background:#667eea;color:#fff;transform:scale(1.05)}.note-textarea-small{width:100%;padding:10px;border:1.5px solid #dee2e6;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;transition:all .2s ease}.note-textarea-small:focus{outline:none;border-color:#667eea;background:#667eea05}.btn-update-inline{width:100%;padding:10px;background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:12px}.btn-update-inline:hover{transform:translateY(-2px);box-shadow:0 4px 12px #11998e4d}.divider-text{text-align:center;margin:20px 0;position:relative}.divider-text:before,.divider-text:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#dee2e6}.divider-text:before{left:0}.divider-text:after{right:0}.divider-text span{background:#fff;padding:0 12px;color:#6c757d;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.note-option{margin-bottom:24px}.note-option label{display:block;color:#333;font-weight:600;margin-bottom:12px;font-size:15px}.note-choices{display:flex;gap:10px;flex-wrap:wrap}.note-choice{flex:1;min-width:70px;padding:12px 16px;border:2px solid #e0e0e0;background:#fff;border-radius:8px;color:#666;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.note-choice:hover{border-color:#667eea;background:#667eea0d}.note-choice.active{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:scale(1.05)}.note-textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:all .2s ease}.note-textarea:focus{outline:none;border-color:#667eea;background:#667eea05}.note-modal-actions{padding:20px 24px;border-top:1px solid #f0f0f0;display:flex;flex-direction:column;gap:12px}.price-breakdown{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#fff5f5,#ffe8e8);border-radius:8px;border:1px solid #ffd0d0;font-size:13px;font-weight:600}.price-breakdown .price-adjust{color:#f5576c}.price-breakdown .total-price{color:#11998e;font-size:15px}.note-modal-actions>div:last-child{display:flex;gap:12px}.btn-save-note,.btn-cancel-note{flex:1;padding:14px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-save-note{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;box-shadow:0 4px 15px #11998e4d}.btn-save-note:hover{transform:translateY(-2px);box-shadow:0 6px 20px #11998e66}.btn-cancel-note{background:#f0f0f0;color:#666}.btn-cancel-note:hover{background:#e0e0e0}.success-toast{position:fixed;top:20px;right:20px;z-index:10000;animation:slideInRight .4s cubic-bezier(.68,-.55,.265,1.55)}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:16px 24px;border-radius:12px;box-shadow:0 10px 30px #10b98166;display:flex;align-items:center;gap:12px;min-width:300px;max-width:500px}.toast-icon{font-size:24px;font-weight:700;background:#fff3;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-message{font-size:15px;font-weight:500;line-height:1.5}.payment-modal{background:#fff;border-radius:20px;width:90%;max-width:450px;box-shadow:0 20px 60px #0000004d;animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.payment-modal-header{padding:24px 24px 20px;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.payment-modal-header h3{margin:0;font-size:20px;color:#333;font-weight:700}.modal-close{background:#f0f0f0;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;color:#666;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:#e74c3c;color:#fff;transform:rotate(90deg)}.payment-modal-body{padding:24px;display:flex;flex-direction:column;gap:12px}.payment-option{display:flex;align-items:center;gap:20px;padding:20px;border-radius:12px;border:2px solid #e0e0e0;background:#fff;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);text-align:left;width:100%}.payment-option:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 25px #00000026}.payment-option.cash{border-color:#38ef7d}.payment-option.cash:hover{background:linear-gradient(135deg,#d4fc79,#96e6a1);border-color:#38ef7d}.payment-option.transfer{border-color:#667eea}.payment-option.transfer:hover{background:linear-gradient(135deg,#a8edea,#fed6e3);border-color:#667eea}.payment-icon{font-size:48px;flex-shrink:0;filter:drop-shadow(2px 2px 6px rgba(0,0,0,.1))}.payment-info{display:flex;flex-direction:column;gap:4px}.payment-title{font-size:18px;font-weight:700;color:#333}.payment-desc{font-size:13px;color:#666;font-weight:500}@media (max-width: 768px){.menu-grid{grid-template-columns:1fr;padding:16px}.menu-header h1{font-size:24px}.summary-content{flex-direction:column;align-items:stretch}.create-qr-btn{width:100%}.success-toast{right:10px;left:10px}.toast-content{min-width:auto}}.payment-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-bottom:40px}.payment-header{background:#fff;padding:20px;text-align:center;box-shadow:0 2px 10px #0000001a}.payment-header h1{color:#333;font-size:28px;margin-bottom:8px}.payment-header p{color:#666;font-size:14px}.payment-content{max-width:600px;margin:20px auto;padding:0 20px}.qr-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000026;margin-bottom:20px}.qr-wrapper{position:relative;width:100%;max-width:400px;margin:0 auto;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#f8f8f8;border-radius:12px;overflow:hidden}.qr-wrapper.loaded{background:#fff}.qr-image{width:100%;height:100%;object-fit:contain;opacity:0;transition:opacity .3s ease}.qr-wrapper.loaded .qr-image{opacity:1}.payment-info{margin-bottom:20px}.info-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px #00000026}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-row.highlight{background:linear-gradient(135deg,#667eea1a,#764ba21a);margin:12px -20px;padding:16px 20px;border-radius:8px;border:none}.info-label{color:#666;font-size:15px}.info-value{color:#333;font-size:16px;font-weight:600}.bill-code{color:#667eea;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease}.bill-code:hover{color:#764ba2}.total-amount{color:#e74c3c;font-size:24px;font-weight:700}.copy-hint{opacity:.6;font-size:14px}.divider{height:1px;background:linear-gradient(to right,transparent,#ddd,transparent);margin:20px 0}.bank-info h3{color:#333;font-size:16px;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #667eea}.bank-detail{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}.bank-label{color:#666}.bank-value{color:#333;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px}.bank-value:hover{color:#667eea}.payment-note{margin-top:16px;padding:12px;background:#fff9e6;border-left:4px solid #ffc107;border-radius:4px}.payment-note p{color:#666;font-size:13px;line-height:1.5;margin:0}.display-link-section{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px #00000026;text-align:center;margin-bottom:20px}.display-link-text{color:#666;font-size:15px;margin-bottom:12px}.display-link-btn{display:inline-block;background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;text-decoration:none;padding:14px 28px;border-radius:12px;font-size:16px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #11998e4d}.display-link-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #11998e66}.payment-success-btn{width:100%;background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border:none;padding:18px;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 24px #11998e66;margin-bottom:12px}.payment-success-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #11998e80}.payment-success-btn:active{transform:translateY(0)}.new-order-btn{width:100%;background:#fff;color:#667eea;border:2px solid #667eea;padding:16px;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.new-order-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.new-order-btn:active{transform:translateY(0)}.loading-container{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}@media (max-width: 768px){.payment-header h1{font-size:24px}.payment-content{padding:0 16px}.qr-section,.info-card{padding:16px}.info-row.highlight{margin:12px -16px;padding:14px 16px}.total-amount{font-size:20px}.new-order-btn{font-size:16px;padding:14px}}@media (min-width: 769px) and (max-width: 1024px){.payment-content{max-width:700px}.qr-wrapper{max-width:450px}}.qr-display-container{min-height:100vh;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;overflow:hidden}.qr-display-container.active{background:linear-gradient(135deg,#11998e,#38ef7d)}.qr-display-header{background:#fff;padding:24px 20px;text-align:center;box-shadow:0 4px 20px #00000026}.qr-display-header h1{color:#333;font-size:32px;margin-bottom:8px;font-weight:700}.cafe-name{color:#666;font-size:18px;font-weight:500}.qr-tabs-container{display:flex;gap:8px;padding:12px 20px;background:#fff;border-bottom:2px solid #f0f0f0;overflow-x:auto;white-space:nowrap}.qr-tabs-container::-webkit-scrollbar{height:4px}.qr-tab{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 20px;background:#f5f5f5;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .3s ease;min-width:100px}.qr-tab:hover{background:#e8e8e8;transform:translateY(-2px)}.qr-tab.active{background:linear-gradient(135deg,#11998e1a,#38ef7d1a);border-color:#11998e;box-shadow:0 4px 12px #11998e33}.qr-tab-label{font-size:13px;font-weight:600;color:#666}.qr-tab.active .qr-tab-label{color:#11998e}.qr-tab-amount{font-size:15px;font-weight:700;color:#333}.qr-tab.active .qr-tab-amount{color:#11998e}.qr-display-content{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:30px;max-width:1400px;margin:0 auto;width:100%;overflow-y:auto}.order-details-section{background:#fff;border-radius:20px;padding:30px;box-shadow:0 8px 32px #0000001a;display:flex;flex-direction:column;height:fit-content}.order-header{margin-bottom:24px;border-bottom:2px solid #f0f0f0;padding-bottom:16px}.order-header h2{font-size:24px;color:#333;margin-bottom:12px}.order-meta{display:flex;gap:12px;align-items:center}.bill-code-chip{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;padding:6px 16px;border-radius:20px;font-size:14px;font-weight:600;letter-spacing:.5px}.table-name{background:#f5f5f5;color:#666;padding:6px 16px;border-radius:20px;font-size:14px;font-weight:500}.order-items-list{max-height:600px;overflow-y:auto;margin-bottom:16px}.order-items-list::-webkit-scrollbar{width:6px}.order-items-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:10px}.order-items-list::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#11998e,#38ef7d);border-radius:10px}.order-item{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding:5px 0;border-bottom:1px solid #f0f0f0;align-items:center}.order-item:last-child{border-bottom:none}.item-info{display:flex;flex-direction:column;gap:2px}.item-name{font-size:14px;font-weight:600;color:#333}.item-note{font-size:11px;color:#555;line-height:1.3;padding:2px 6px;background:#11998e0d;border-radius:4px;border-left:2px solid #11998e}.item-quantity{font-size:13px;font-weight:600;color:#666;min-width:30px;text-align:center}.item-price{font-size:14px;font-weight:700;color:#11998e;min-width:100px;text-align:right}.empty-items{text-align:center;padding:40px;color:#999;font-size:16px}.order-summary{border-radius:16px;padding:20px;margin-top:20px}.summary-row{display:flex;justify-content:space-between;padding:10px 0;font-size:16px}.summary-row.subtotal{color:#666}.summary-row.discount{color:#f59e0b;font-weight:600}.summary-row.total{font-size:20px;font-weight:700;color:#11998e;border-top:2px solid #e0e0e0;padding-top:16px;margin-top:8px}.qr-section{background:#fff;border-radius:20px;padding:30px;box-shadow:0 8px 32px #0000001a;display:flex;flex-direction:column;align-items:center;gap:24px;height:fit-content;position:sticky;top:30px}.qr-display-wrapper{position:relative;width:100%;max-width:360px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#f8f8f8;border-radius:16px;overflow:hidden}.qr-display-wrapper.loaded{background:#fff}.qr-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.qr-display-image{width:100%;height:100%;object-fit:contain;opacity:0;transition:opacity .5s ease;animation:forceShow 2s forwards}@keyframes forceShow{0%{opacity:0}90%{opacity:0}to{opacity:1}}.qr-display-wrapper.loaded .qr-display-image{opacity:1;animation:none}.qr-info-section{background:#fff;border-radius:20px;padding:24px;box-shadow:0 8px 32px #0003;margin-bottom:20px}.amount-display{text-align:center;padding:20px;background:linear-gradient(135deg,#11998e1a,#38ef7d1a);border-radius:16px;margin-bottom:20px}.amount-label{display:block;color:#666;font-size:16px;margin-bottom:8px}.amount-value{display:block;color:#11998e;font-size:36px;font-weight:700}.subtotal-display{text-align:center;padding:12px 16px;background:#f8f8f8;border-radius:12px;margin-bottom:12px}.subtotal-label{display:block;color:#666;font-size:14px;margin-bottom:6px}.subtotal-value{display:block;color:#333;font-size:20px;font-weight:600;text-decoration:line-through;opacity:.7}.voucher-display{text-align:center;padding:12px 16px;background:linear-gradient(135deg,#10b9811a,#0596691a);border:2px solid #10b981;border-radius:12px;margin-bottom:12px}.voucher-label{display:block;color:#059669;font-size:14px;font-weight:600;margin-bottom:6px}.voucher-value{display:block;color:#10b981;font-size:22px;font-weight:700}.bill-code-display{text-align:center;padding:16px;background:#f8f8f8;border-radius:12px;margin-bottom:20px}.bill-label{display:block;color:#666;font-size:14px;margin-bottom:6px}.bill-value{display:block;color:#333;font-size:20px;font-weight:600;font-family:Courier New,monospace}.bank-info-compact{text-align:center;color:#666;font-size:14px;line-height:1.8}.bank-info-compact p{margin:4px 0}.payment-info{width:100%;display:flex;flex-direction:column;gap:20px}.bank-info{background:#f8f8f8;border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:12px}.bank-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.bank-label{font-size:14px;color:#666;font-weight:500}.bank-value{font-size:14px;color:#333;font-weight:600;text-align:right}.bill-code-text{color:#11998e;font-weight:700;letter-spacing:.5px}.instructions{background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:12px}.instructions p{color:#555;font-size:15px;margin:0;font-weight:500}.payment-received-btn{width:100%;background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border:none;padding:18px 24px;border-radius:16px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 24px #11998e66;margin-top:20px;display:flex;align-items:center;justify-content:center;gap:10px}.payment-received-btn:hover{transform:translateY(-3px);box-shadow:0 8px 30px #11998e80}.payment-received-btn:active{transform:translateY(-1px);box-shadow:0 4px 20px #11998e66}.payment-received-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auto-refresh-indicator{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#fffffff2;padding:12px 24px;border-radius:30px;box-shadow:0 4px 15px #0003;display:flex;align-items:center;gap:10px;color:#666;font-size:14px;font-weight:500}.pulse-dot{width:10px;height:10px;background:#11998e;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.waiting-screen,.loading-screen{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:24px;color:#fff;text-align:center;padding:20px}.waiting-icon{font-size:80px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.waiting-screen h1{font-size:32px;margin:0}.waiting-screen p{font-size:18px;opacity:.9}.pulse-animation{width:80px;height:80px;border:4px solid rgba(255,255,255,.3);border-radius:50%;animation:pulse-ring 2s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(.8);opacity:1}to{transform:scale(1.4);opacity:0}}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.loading-spinner.small{width:40px;height:40px;border-width:3px}@media (max-width: 968px){.qr-display-content{grid-template-columns:1fr;gap:20px;padding:20px}.qr-section{position:relative;top:0}.order-details-section{order:2}.qr-section{order:1}}@media (max-width: 768px){.qr-display-header h1{font-size:24px}.cafe-name{font-size:16px}.qr-display-content{padding:16px;gap:16px}.order-details-section,.qr-section{padding:20px}.order-header h2{font-size:20px}.order-item{grid-template-columns:1fr auto;gap:12px}.item-price{grid-column:1 / -1;text-align:left;margin-top:4px;font-size:18px}.qr-display-wrapper{max-width:280px}.amount-value{font-size:28px}.instructions{padding:16px}.instructions p{font-size:14px}}.qr-main-section,.qr-info-section,.instructions{padding:20px}.amount-value{font-size:28px}.bill-value{font-size:18px}.instructions p{font-size:15px}@media (max-width: 768px) and (orientation: landscape){.qr-display-content{flex-direction:row;flex-wrap:wrap;gap:16px}.qr-main-section{flex:0 0 45%}.qr-info-section{flex:0 0 52%}.instructions{flex:1 1 100%}}.history-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding-bottom:40px}.history-header{background:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100}.back-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.back-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.history-header h1{color:#333;font-size:28px;margin:0}.history-stats{background:#f0f0f0;padding:8px 16px;border-radius:20px;font-size:14px;color:#666;font-weight:600}.history-content{max-width:1400px;margin:0 auto;padding:30px 20px}.history-search{margin-bottom:30px}.search-box{position:relative;display:flex;align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:0 20px;transition:all .3s ease}.search-box:focus-within{box-shadow:0 6px 30px #667eea4d;transform:translateY(-2px)}.search-icon{font-size:20px;margin-right:12px;color:#999}.search-input{flex:1;border:none;outline:none;padding:16px 0;font-size:16px;color:#333;background:transparent}.search-input::placeholder{color:#999}.search-clear{background:#e0e0e0;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:16px;color:#666;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.search-clear:hover{background:#d0d0d0;transform:scale(1.1)}.search-results-info{margin-top:12px;color:#fff;font-size:14px;text-align:center}.search-results-info strong{font-weight:700;font-size:16px}.history-empty{text-align:center;padding:100px 20px;color:#fff}.history-empty p:first-child{font-size:80px;margin-bottom:20px}.history-empty p:last-child{font-size:20px}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.history-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px #0000001a;transition:all .3s ease}.history-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #00000026}.history-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid #f0f0f0}.history-card-info{display:flex;flex-direction:column;gap:6px}.history-bill-code{font-size:18px;font-weight:700;color:#333}.history-tab-name{font-size:13px;color:#667eea;font-weight:600;background:#667eea1a;padding:4px 12px;border-radius:12px;display:inline-block}.history-card-total{font-size:24px;font-weight:700;color:#e74c3c}.history-card-time{font-size:13px;color:#999;margin-bottom:16px}.history-payment-method{margin-bottom:12px}.payment-badge{display:inline-block;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600}.payment-badge.cash{background:linear-gradient(135deg,#d4fc79,#96e6a1);color:#1a5d1a}.payment-badge.transfer{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#764ba2}.history-voucher-info{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e9;border-radius:8px;padding:10px 12px;margin-bottom:16px;font-size:13px;color:#333;font-weight:500}.history-card-items{background:#f8f8f8;border-radius:12px;padding:12px;margin-bottom:16px}.history-product{padding:8px 0;border-bottom:1px solid #e0e0e0}.history-product:last-child{border-bottom:none}.product-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.product-name{font-size:14px;font-weight:600;color:#333}.product-qty{font-size:14px;color:#667eea;font-weight:700;background:#667eea1a;padding:2px 8px;border-radius:8px}.history-note{font-size:12px;color:#666;font-style:italic;margin-top:4px}.history-print-btn{width:100%;background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border:none;padding:12px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.history-print-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #11998e4d}@media (max-width: 768px){.history-header{flex-direction:column;gap:12px;align-items:flex-start}.history-header h1{font-size:22px}.history-stats{align-self:flex-start}.history-content{padding:20px 15px}.stats-header{flex-direction:column;gap:12px;align-items:flex-start}.stats-toggle{width:100%}.stats-grid{grid-template-columns:1fr;gap:15px}.stat-value{font-size:24px}.voucher-chart{flex:0 0 80px}.history-grid{grid-template-columns:1fr}.search-input{font-size:14px}.search-results-info{font-size:12px}}.cms-container{min-height:100vh;display:flex;background:#f5f7fa}.cms-sidebar{width:280px;background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;box-shadow:4px 0 20px #0000001a;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-header{padding:32px 24px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{font-size:28px;margin:0 0 8px;font-weight:700}.sidebar-subtitle{margin:0;font-size:14px;color:#fffc;font-weight:400}.sidebar-nav{flex:1;padding:24px 0}.sidebar-tab{width:100%;display:flex;align-items:center;gap:12px;padding:14px 24px;background:transparent;border:none;border-left:4px solid transparent;color:#fffc;font-size:15px;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:left}.sidebar-tab:hover{background:#ffffff1a;color:#fff;border-left-color:#ffffff4d}.sidebar-tab.active{background:#ffffff26;color:#fff;border-left-color:#fff;box-shadow:inset 0 0 20px #0000001a}.tab-icon{font-size:20px;width:28px;display:inline-block;text-align:center}.tab-label{flex:1}.btn-back-sidebar{margin:20px 24px 24px;padding:12px 20px;background:#ffffff1a;border:2px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-back-sidebar:hover{background:#fff3;border-color:#fff;transform:translate(-2px)}.cms-main{flex:1;overflow-y:auto}.cms-content{padding:40px;background:#fff;min-height:calc(100vh - 80px);margin:20px;border-radius:16px;box-shadow:0 2px 10px #0000000d}.loading-spinner{width:50px;height:50px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.cms-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cms-toolbar h2{font-size:24px;color:#2d3748;margin:0}.btn-add{background:linear-gradient(135deg,#48c6ef,#6f86d6);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #48c6ef4d}.btn-add:hover{transform:translateY(-2px);box-shadow:0 4px 15px #48c6ef66}.menu-table-wrapper{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #00000014}.cms-table{width:100%;border-collapse:collapse}.cms-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.cms-table th{padding:16px;text-align:left;font-weight:600;font-size:14px}.cms-table td{padding:16px;border-bottom:1px solid #e2e8f0;color:#4a5568}.cms-table tbody tr:hover{background:#f7fafc}.btn-edit,.btn-delete{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;margin-right:8px;transition:all .2s ease}.btn-edit{background:#edf2f7;color:#4299e1}.btn-edit:hover{background:#4299e1;color:#fff}.btn-delete{background:#fff5f5;color:#e53e3e}.btn-delete:hover{background:#e53e3e;color:#fff}.user-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.user-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 10px #00000014;transition:all .3s ease}.user-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0000001f}.user-avatar{width:60px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0}.user-info{flex:1}.user-info h3{margin:0 0 8px;font-size:18px;color:#2d3748}.user-role{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.user-role.admin{background:#fef5e7;color:#d68910}.user-role.staff{background:#e8f5e9;color:#388e3c}.btn-delete-user{width:40px;height:40px;border:none;border-radius:8px;background:#fff5f5;color:#e53e3e;font-size:18px;cursor:pointer;transition:all .2s ease}.btn-delete-user:hover:not(:disabled){background:#e53e3e;color:#fff}.btn-delete-user:disabled{opacity:.3;cursor:not-allowed}.settings-form{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #00000014}.settings-section{margin-bottom:40px;padding-bottom:30px;border-bottom:2px solid #e2e8f0}.settings-section:last-of-type{border-bottom:none}.settings-section h3{font-size:20px;color:#2d3748;margin-bottom:20px}.settings-form .form-group{margin-bottom:20px}.settings-form label{display:block;font-size:14px;font-weight:600;color:#4a5568;margin-bottom:8px}.settings-form input[type=text],.settings-form input[type=number],.settings-form select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .3s ease}.settings-form input:focus,.settings-form select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.settings-form input[type=checkbox]{margin-right:8px;width:18px;height:18px;cursor:pointer}.btn-save-settings{background:linear-gradient(135deg,#48c6ef,#6f86d6);color:#fff;border:none;padding:14px 32px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #48c6ef4d;width:100%;margin-top:20px}.btn-save-settings:hover{transform:translateY(-2px);box-shadow:0 4px 15px #48c6ef66}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 30px;border-bottom:2px solid #e2e8f0}.modal-header h2{margin:0;font-size:22px;color:#2d3748}.modal-close{width:36px;height:36px;border:none;background:#f7fafc;border-radius:8px;font-size:24px;color:#718096;cursor:pointer;transition:all .2s ease}.modal-close:hover{background:#e2e8f0;color:#2d3748}.modal-form{padding:30px;overflow-y:auto;flex:1;min-height:0}.modal-form .form-group{margin-bottom:20px}.modal-form label{display:block;font-size:14px;font-weight:600;color:#4a5568;margin-bottom:8px}.modal-form input,.modal-form select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .3s ease}.modal-form input:focus,.modal-form select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-actions{display:flex;gap:12px;margin-top:30px}.btn-cancel,.btn-submit{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel{background:#f7fafc;color:#718096}.btn-cancel:hover{background:#e2e8f0;color:#2d3748}.btn-submit{background:linear-gradient(135deg,#48c6ef,#6f86d6);color:#fff;box-shadow:0 2px 10px #48c6ef4d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 4px 15px #48c6ef66}.option-groups-checkboxes{display:flex;flex-wrap:wrap;gap:12px;padding:20px;background:#fff;border-radius:12px;border:2px solid #e8ecf4}.option-group-checkbox{position:relative;display:inline-flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border-radius:8px;border:1.5px solid #e2e8f0;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.option-group-checkbox:hover{border-color:#48bb78;background:#f0fff4;box-shadow:0 2px 6px #48bb7826}.option-group-checkbox input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid #cbd5e0;border-radius:4px;cursor:pointer;position:relative;transition:all .2s ease;background:#fff;flex-shrink:0;margin:0}.option-group-checkbox input[type=checkbox]:hover{border-color:#48bb78}.option-group-checkbox input[type=checkbox]:checked{background:#48bb78;border-color:#48bb78}.option-group-checkbox input[type=checkbox]:checked:after{content:"✓";position:absolute;color:#fff;font-size:12px;font-weight:700;top:50%;left:50%;transform:translate(-50%,-50%)}.option-group-text{display:flex;align-items:center;gap:8px}.option-group-name{font-weight:600;color:#2d3748;font-size:14px}.option-group-hint{color:#a0aec0;font-size:13px;font-weight:400}@media (max-width: 768px){.cms-header-content{flex-direction:column;gap:16px}.cms-tabs{overflow-x:auto}.cms-tab{padding:12px 20px;font-size:14px;white-space:nowrap}.cms-toolbar{flex-direction:column;gap:16px;align-items:flex-start}.btn-add{width:100%}.menu-table-wrapper{overflow-x:auto}.user-cards{grid-template-columns:1fr}}.options-management{min-height:400px}.option-groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-top:20px}.option-group-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 10px #00000014;transition:box-shadow .3s ease,border-color .3s ease;border:2px solid transparent;height:fit-content;position:relative;will-change:auto}.option-group-card:hover{box-shadow:0 6px 20px #0000001f;border-color:#667eea}.group-header{margin-bottom:16px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}.group-title h3{margin:0 0 8px;font-size:20px;color:#2d3748}.group-key{font-size:13px;color:#718096;font-family:Courier New,monospace;background:#f7fafc;padding:4px 8px;border-radius:4px}.group-badges{display:flex;gap:8px;margin-top:12px}.badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge.single{background:#e6f7ff;color:#0050b3}.badge.multiple{background:#f0f5ff;color:#5b3cc4}.badge.required{background:#fff1f0;color:#cf1322}.group-options{margin:16px 0}.option-item{padding:8px 12px;background:#f7fafc;border-radius:6px;margin-bottom:8px;font-size:14px;color:#4a5568;border:2px solid transparent;transition:all .2s ease}.option-item.default-option{background:linear-gradient(135deg,#f0fff4,#e6ffed);border:2px solid #48bb78;box-shadow:0 2px 8px #48bb7826}.option-item.default-option .option-label{color:#22543d;font-weight:600}.option-label{font-weight:500}.group-actions{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:2px solid #e2e8f0}.modal-large{max-width:700px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.options-section{margin:24px 0;padding:20px;background:#f7fafc;border-radius:8px}.options-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.options-header label{margin:0;font-size:16px;font-weight:700;color:#2d3748}.btn-add-option{background:#48c6ef;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-add-option:hover{background:#3ba3c7}.options-list{display:flex;flex-direction:column;gap:12px}.option-row{display:flex;gap:12px;align-items:flex-start;padding:12px;background:#fff;border-radius:8px;border:2px solid #e2e8f0}.option-fields{flex:1;display:grid;grid-template-columns:1fr 1.5fr 1fr auto;gap:8px;align-items:center}.option-fields input[type=text],.option-fields input[type=number]{padding:8px 12px;font-size:13px;margin:0}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;white-space:nowrap;margin:0;padding:0}.checkbox-label input[type=checkbox]{width:auto;margin:0}.btn-remove-option{width:36px;height:36px;border:none;background:#fff5f5;color:#e53e3e;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s ease;flex-shrink:0}.btn-remove-option:hover:not(:disabled){background:#e53e3e;color:#fff}.btn-remove-option:disabled{opacity:.3;cursor:not-allowed}.reports-management{padding:30px}.report-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px}.report-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #00000014;transition:all .3s ease;border:2px solid transparent}.report-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001f}.report-card.card-primary{border-color:#667eea;background:linear-gradient(135deg,#667eea15,#fff)}.report-card.card-success{border-color:#48bb78;background:linear-gradient(135deg,#48bb7815,#fff)}.report-card.card-info{border-color:#4299e1;background:linear-gradient(135deg,#4299e115,#fff)}.report-card.card-warning{border-color:#ed8936;background:linear-gradient(135deg,#ed893615,#fff)}.report-card.card-purple{border-color:#9f7aea;background:linear-gradient(135deg,#9f7aea15,#fff)}.report-icon{font-size:40px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#fffc;border-radius:12px;flex-shrink:0}.report-content{flex:1}.report-content h3{margin:0 0 8px;font-size:14px;color:#718096;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.report-value{margin:0;font-size:20px;font-weight:700;color:#2d3748;line-height:1.2}.report-label{font-size:12px;color:#a0aec0}.report-section{background:#fff;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 8px #00000014}.section-title{margin:0 0 24px;font-size:20px;color:#2d3748;font-weight:600;display:flex;align-items:center;gap:8px}.top-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.top-item{display:flex;align-items:center;gap:16px;padding:16px;background:#f7fafc;border-radius:10px;border:2px solid #e2e8f0;transition:all .2s ease}.top-item:hover{border-color:#667eea;background:#f0f4ff}.top-item-rank{width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.top-item-info h4{margin:0 0 4px;font-size:15px;color:#2d3748;font-weight:600}.top-item-info p{margin:0;font-size:13px;color:#718096}.staff-revenue-list{display:flex;flex-direction:column;gap:12px}.staff-revenue-item{display:flex;align-items:center;gap:20px;padding:16px 20px;background:#f7fafc;border-radius:10px;border:2px solid #e2e8f0;transition:all .2s ease}.staff-revenue-item:hover{border-color:#48bb78;background:#f0fff4}.staff-info{display:flex;align-items:center;gap:12px;min-width:200px}.staff-avatar{width:44px;height:44px;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0}.staff-name{font-size:16px;font-weight:600;color:#2d3748}.staff-revenue-chart{flex:1}.revenue-bar-container{background:#e2e8f0;border-radius:8px;height:36px;overflow:hidden;position:relative}.revenue-bar{background:linear-gradient(90deg,#48bb78,#38a169);height:100%;min-width:120px;display:flex;align-items:center;justify-content:flex-end;padding-right:12px;border-radius:8px;transition:width .8s ease;box-shadow:inset 0 2px 4px #0000001a}.revenue-bar-label{color:#fff;font-weight:600;font-size:14px;text-shadow:0 1px 2px rgba(0,0,0,.2)}.chart-container{padding:20px;background:#f7fafc;border-radius:12px}.bar-chart{display:flex;align-items:flex-end;justify-content:space-around;gap:30px;height:300px;padding:20px;background:#fff;border-radius:10px;border:2px solid #e2e8f0}.chart-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:12px}.bar-wrapper{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;position:relative}.bar{width:80%;min-height:40px;border-radius:8px 8px 0 0;position:relative;transition:all .8s cubic-bezier(.4,0,.2,1);display:flex;align-items:flex-start;justify-content:center;padding-top:12px;box-shadow:0 -4px 12px #0000001a}.bar-today{background:linear-gradient(180deg,#48bb78,#38a169)}.bar-week{background:linear-gradient(180deg,#4299e1,#3182ce)}.bar-month{background:linear-gradient(180deg,#667eea,#764ba2)}.bar-custom{background:linear-gradient(180deg,#ed8936,#dd6b20)}.bar-value{color:#fff;font-weight:700;font-size:13px;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.2);writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}.date-range-selector{display:flex;align-items:flex-end;gap:16px;padding:20px;background:#fff;border-radius:10px;border:2px solid #e2e8f0;margin-bottom:20px;flex-wrap:wrap}.date-input-group{display:flex;flex-direction:column;gap:8px}.date-input-group label{font-size:14px;font-weight:600;color:#2d3748}.date-input-group input[type=date]{padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:500;color:#2d3748;transition:all .2s ease;min-width:160px}.date-input-group input[type=date]:focus{outline:none;border-color:#48bb78;box-shadow:0 0 0 3px #48bb781a}.date-input-group input[type=date]:hover{border-color:#cbd5e0}.btn-apply-date{padding:10px 24px;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #48bb784d}.btn-apply-date:hover{transform:translateY(-2px);box-shadow:0 4px 12px #48bb7866}.btn-apply-date:active{transform:translateY(0)}.line-chart-container{padding:30px;background:#fff;border-radius:12px;border:2px solid #e2e8f0}.line-chart{width:100%;height:auto;max-height:400px;background:#fafafa;border-radius:8px;padding:10px}.grid-lines line{stroke-dasharray:5,5}.chart-legend{display:flex;justify-content:center;gap:30px;margin-top:20px;padding:16px;background:#f7fafc;border-radius:8px}.legend-item-line{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#2d3748}.legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.chart-tooltip{background:#000000d9;color:#fff;padding:10px 14px;border-radius:6px;font-size:13px;font-weight:500;white-space:nowrap;z-index:1000;box-shadow:0 4px 12px #0000004d;line-height:1.6}.chart-tooltip div:first-child{font-weight:700;margin-bottom:2px;color:#a5f3fc}.bar-label{color:#fff;font-weight:700;font-size:13px;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.2);writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}.bar-label{font-size:14px;font-weight:600;color:#2d3748;text-align:center}.pie-chart-container{display:flex;gap:40px;align-items:center;justify-content:center;padding:20px}.pie-chart{display:flex;width:280px;height:280px;border-radius:50%;overflow:hidden;box-shadow:0 8px 24px #00000026;position:relative}.pie-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;text-shadow:0 2px 4px rgba(0,0,0,.3);position:relative}.pie-segment:hover{filter:brightness(1.15);transform:scale(1.05);z-index:10}.pie-percentage{writing-mode:vertical-rl;text-orientation:mixed}.pie-legend{display:flex;flex-direction:column;gap:12px;flex:1;max-width:300px}.legend-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s ease}.legend-item:hover{background:#fff;border-color:#cbd5e0;transform:translate(4px)}.legend-color{width:20px;height:20px;border-radius:4px;flex-shrink:0}.legend-label{flex:1;font-weight:600;color:#2d3748;font-size:14px}.legend-value{font-size:13px;color:#718096;font-weight:500}@media (max-width: 768px){.pie-chart-container{flex-direction:column}.pie-chart{width:240px;height:240px}.bar-chart{gap:15px;padding:15px}.staff-revenue-item{flex-direction:column;align-items:flex-start;gap:12px}.staff-info{width:100%}.option-groups-grid,.form-row,.option-fields{grid-template-columns:1fr}.modal-large{max-width:100%}}.voucher-management{width:100%}.voucher-table-wrapper{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #00000014}.voucher-table{width:100%;border-collapse:collapse}.voucher-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.voucher-table th{padding:16px 12px;text-align:left;font-weight:600;font-size:13px;white-space:nowrap}.voucher-table td{padding:16px 12px;border-bottom:1px solid #e2e8f0;font-size:14px}.voucher-table tbody tr{transition:background .2s ease}.voucher-table tbody tr:hover{background:#f7fafc}.voucher-table tbody tr.inactive{opacity:.5;background:#f5f5f5}.voucher-type{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.voucher-type.fixed{background:#dbeafe;color:#1e40af}.voucher-type.percent{background:#dcfce7;color:#15803d}.btn-toggle-status{padding:6px 14px;border:none;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-toggle-status.active{background:#d1fae5;color:#065f46}.btn-toggle-status.active:hover{background:#10b981;color:#fff}.btn-toggle-status.inactive{background:#fee2e2;color:#991b1b}.btn-toggle-status.inactive:hover{background:#ef4444;color:#fff}.btn-edit-small,.btn-delete-small{padding:6px 10px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease}.btn-edit-small{background:#dbeafe;color:#1e40af}.btn-edit-small:hover{background:#3b82f6;color:#fff}.btn-delete-small{background:#fee2e2;color:#991b1b}.btn-delete-small:hover{background:#ef4444;color:#fff}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:500;color:#4a5568}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.voucher-modal .form-group textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:all .3s ease;resize:vertical;min-height:60px;line-height:1.5;background:#f8fafc}.voucher-modal .form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.voucher-modal .form-group textarea::placeholder{color:#a0aec0;font-style:italic}.voucher-section{background:#fff;border-radius:16px;padding:30px;margin-bottom:30px}.voucher-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.voucher-stat-card{border-radius:16px;padding:25px;display:flex;gap:20px;align-items:center;transition:all .3s ease;box-shadow:0 4px 12px #00000014}.voucher-stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000001f}.voucher-stat-card.primary{background:linear-gradient(135deg,#fff5f5,#ffe5e5);border:2px solid #ff6b9d}.voucher-stat-card.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #10b981}.voucher-stat-card.info{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e9}.voucher-stat-card .stat-icon{font-size:48px;filter:drop-shadow(2px 2px 6px rgba(0,0,0,.1))}.voucher-stat-card .stat-info{flex:1}.voucher-stat-card .stat-label{font-size:13px;color:#666;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.voucher-stat-card .stat-value{font-size:20px;font-weight:700;color:#1a202c;margin-bottom:4px;line-height:1}.voucher-stat-card .stat-detail{font-size:13px;color:#718096;font-weight:500}.top-vouchers-container{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:16px;padding:25px;margin-bottom:25px}.subsection-title{font-size:20px;color:#1a202c;margin:0 0 20px;font-weight:700}.voucher-list{display:flex;flex-direction:column;gap:15px}.voucher-item{background:#fff;border-radius:12px;padding:18px;display:flex;align-items:center;gap:15px;transition:all .3s ease;box-shadow:0 2px 8px #0000000f}.voucher-item:hover{transform:translate(8px);box-shadow:0 4px 16px #0000001f}.voucher-rank{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0;box-shadow:0 4px 10px #667eea4d}.voucher-details{flex:1}.voucher-code{font-size:17px;font-weight:700;color:#1a202c;margin-bottom:6px}.voucher-meta{font-size:14px;color:#718096}.voucher-meta strong{color:#667eea;font-weight:700}.voucher-chart{flex:0 0 140px;height:10px;background:#e2e8f0;border-radius:10px;overflow:hidden}.voucher-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .8s cubic-bezier(.4,0,.2,1)}.voucher-insights{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:25px}.insight-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid #f1f5f9}.insight-row:last-child{border-bottom:none}.insight-row.total{font-weight:700;font-size:18px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);padding:18px;border-radius:10px;margin-top:10px}.insight-row .insight-label{color:#4a5568;font-size:16px;font-weight:600}.insight-row .insight-value{color:#1a202c;font-size:17px;font-weight:700}.insight-row.negative .insight-value{color:#e53e3e}.insight-row.total .insight-label,.insight-row.total .insight-value{color:#0ea5e9;font-size:19px;font-weight:700}@media (max-width: 768px){.voucher-stats-grid{grid-template-columns:1fr}.voucher-stat-card .stat-value{font-size:26px}.voucher-chart{flex:0 0 90px}.voucher-insights{padding:18px}.insight-row{flex-direction:column;align-items:flex-start;gap:8px}}.bank-accounts-list{display:flex;flex-direction:column;gap:16px}.bank-account-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:20px;display:flex;justify-content:space-between;align-items:flex-start;transition:all .3s ease}.bank-account-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.bank-account-card.primary{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.bank-account-info{flex:1}.bank-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.bank-header h4{margin:0;font-size:18px;color:#1a202c;font-weight:700}.primary-badge{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.bank-details{display:flex;flex-direction:column;gap:8px}.bank-detail-row{display:flex;gap:8px;font-size:14px}.bank-detail-row .label{color:#718096;font-weight:600;min-width:60px}.bank-detail-row .value{color:#1a202c;font-weight:500}.bank-account-actions{display:flex;gap:8px;align-items:flex-start}.btn-set-primary{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;border:none;padding:8px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-set-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #fbbf2466}.btn-add-small{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-add-small:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.bank-modal{max-width:550px}.bank-modal .modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:28px 32px;border-radius:20px 20px 0 0}.bank-modal .modal-header h2{color:#fff;font-size:24px;margin:0}.bank-modal .modal-close{background:#fff3;color:#fff;width:36px;height:36px;font-size:24px}.bank-modal .modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.bank-modal .modal-body{padding:32px}.bank-modal .form-group{margin-bottom:24px}.bank-modal .form-group label{display:block;margin-bottom:10px;color:#2d3748;font-weight:600;font-size:15px}.bank-modal .form-group label:after{content:" *";color:#e53e3e;font-weight:700}.bank-modal .form-group input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;transition:all .3s ease;background:#f8fafc}.bank-modal .form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.bank-modal .form-group input::placeholder{color:#a0aec0;font-weight:400}.bank-modal .modal-actions{display:flex;gap:12px;margin-top:32px;padding-top:24px;border-top:2px solid #f0f0f0}.bank-modal .btn-cancel{flex:1;padding:14px 24px;background:#f0f0f0;color:#666;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.bank-modal .btn-cancel:hover{background:#e0e0e0;transform:translateY(-2px)}.bank-modal .btn-submit{flex:2;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.bank-modal .btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.bank-search-wrapper{position:relative}.bank-dropdown{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 8px 24px #0000001f;z-index:1000;margin-top:4px}.bank-dropdown-item{padding:12px 16px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f5f5f5;font-size:14px;color:#333}.bank-dropdown-item:last-child{border-bottom:none}.bank-dropdown-item:hover{background:linear-gradient(135deg,#667eea15,#764ba215);color:#667eea;padding-left:20px}.bank-dropdown::-webkit-scrollbar{width:6px}.bank-dropdown::-webkit-scrollbar-track{background:#f5f5f5;border-radius:10px}.bank-dropdown::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px}.bank-dropdown::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#764ba2,#667eea)}.printer-config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:20px}.printer-config-card{background:linear-gradient(135deg,#f8f9ff,#fff);border:2px solid #e8ecff;border-radius:16px;padding:24px;transition:all .3s ease}.printer-config-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #667eea26;border-color:#667eea}.printer-config-card h4{font-size:18px;color:#333;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #e8ecff}.printer-config-card .form-group{margin-bottom:16px}.printer-config-card .form-group:last-child{margin-bottom:0}.printer-config-card select{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:14px;transition:all .3s ease}.printer-config-card select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.printer-config-card label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#555}.printer-config-card input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}@media (max-width: 768px){.bank-account-card{flex-direction:column;gap:16px}.bank-account-actions{width:100%;justify-content:flex-end}.bank-dropdown{max-height:200px}.printer-config-grid{grid-template-columns:1fr;gap:16px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}#root{min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}
