:root{--hgp-primary:#1e3a5f;--hgp-accent:#e8830a;--hgp-green:#2ecc71;--hgp-red:#e74c3c;--hgp-light:#f8fafc;--hgp-border:#e2e8f0;--hgp-shadow:0 4px 16px rgba(0,0,0,.08);}
*{box-sizing:border-box;}
.hgp-dashboard{max-width:900px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:#333;}
.hgp-login-required,.hgp-no-guest{background:var(--hgp-light);border-radius:12px;padding:32px;text-align:center;font-size:16px;}
.hgp-login-required a{color:var(--hgp-accent);font-weight:600;}
.hgp-header{background:var(--hgp-primary);color:#fff;border-radius:14px;padding:24px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.hgp-header-left h2{margin:0;font-size:20px;}
.hgp-header-left p{margin:4px 0 0;opacity:.75;font-size:14px;}
.hgp-status-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;}
.hgp-status-pill.checked-in{background:rgba(46,204,113,.25);color:#1a8c4e;}
.hgp-status-pill.reserved{background:rgba(243,156,18,.25);color:#9a6500;}
.hgp-status-pill.no-booking{background:rgba(255,255,255,.15);color:rgba(255,255,255,.8);}
.hgp-logout-btn{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3);padding:7px 16px;border-radius:8px;cursor:pointer;font-size:13px;text-decoration:none;}
.hgp-tabs{display:flex;border-bottom:2px solid var(--hgp-border);margin-bottom:20px;overflow-x:auto;}
.hgp-tab{padding:10px 20px;cursor:pointer;background:none;border:none;font-size:14px;font-weight:600;color:#666;border-bottom:3px solid transparent;white-space:nowrap;transition:.2s;}
.hgp-tab:hover{color:var(--hgp-primary);}
.hgp-tab.active{color:var(--hgp-primary);border-bottom-color:var(--hgp-accent);}
.hgp-tab-pane{display:none;}.hgp-tab-pane.active{display:block;}
.hgp-card{background:#fff;border-radius:12px;box-shadow:var(--hgp-shadow);padding:20px;margin-bottom:16px;border:1px solid var(--hgp-border);}
.hgp-card h3{margin:0 0 16px;font-size:16px;color:var(--hgp-primary);}
.hgp-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:600px){.hgp-card-grid{grid-template-columns:1fr;}}
.hgp-stat-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;}
@media(max-width:500px){.hgp-stat-tiles{grid-template-columns:1fr 1fr;}}
.hgp-stat-tile{background:#fff;border-radius:10px;padding:16px;text-align:center;border:1px solid var(--hgp-border);box-shadow:0 2px 8px rgba(0,0,0,.05);}
.hgp-stat-tile .tile-icon{font-size:24px;margin-bottom:6px;}
.hgp-stat-tile .tile-val{font-size:20px;font-weight:700;color:var(--hgp-primary);}
.hgp-stat-tile .tile-label{font-size:11px;color:#888;margin-top:2px;}
.hgp-items-list{list-style:none;padding:0;margin:0;}
.hgp-item-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--hgp-border);gap:10px;}
.hgp-item-row:last-child{border:none;}
.hgp-item-desc{flex:1;font-size:14px;}
.hgp-item-desc small{display:block;color:#888;font-size:12px;}
.hgp-item-amount{font-weight:700;font-size:14px;white-space:nowrap;}
.hgp-item-amount.open{color:var(--hgp-red);}
.hgp-item-amount.paid{color:var(--hgp-green);}
.hgp-empty-state{text-align:center;padding:24px;color:#aaa;font-size:14px;}
.hgp-invoice-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--hgp-border);gap:10px;flex-wrap:wrap;}
.hgp-invoice-row:last-child{border:none;}
.hgp-invoice-meta{flex:1;}
.hgp-invoice-meta strong{font-size:14px;display:block;}
.hgp-invoice-meta span{font-size:12px;color:#888;}
.hgp-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.hgp-badge.paid{background:#d5f5e3;color:#1a8449;}
.hgp-badge.open{background:#fadbd8;color:#922b21;}
.hgp-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;border:none;cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;transition:.2s;line-height:1;}
.hgp-btn-primary{background:var(--hgp-primary);color:#fff;}.hgp-btn-primary:hover{background:#16304f;color:#fff;}
.hgp-btn-accent{background:var(--hgp-accent);color:#fff;}.hgp-btn-accent:hover{background:#c97009;color:#fff;}
.hgp-btn-success{background:var(--hgp-green);color:#fff;}
.hgp-btn-danger{background:var(--hgp-red);color:#fff;}
.hgp-btn-outline{background:transparent;border:2px solid var(--hgp-primary);color:var(--hgp-primary);}
.hgp-btn-sm{padding:5px 12px;font-size:12px;}
.hgp-form-group{margin-bottom:14px;}
.hgp-label{display:block;font-size:13px;font-weight:600;margin-bottom:5px;color:#444;}
.hgp-input,.hgp-select{width:100%;padding:9px 13px;border:1.5px solid var(--hgp-border);border-radius:8px;font-size:14px;transition:.2s;}
.hgp-input:focus,.hgp-select:focus{border-color:var(--hgp-primary);outline:none;box-shadow:0 0 0 3px rgba(30,58,95,.1);}
.hgp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:500px){.hgp-form-grid{grid-template-columns:1fr;}}
.hgp-notice{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;font-weight:600;}
.hgp-notice-success{background:#d5f5e3;color:#1e8449;border-left:4px solid #27ae60;}
.hgp-notice-error{background:#fadbd8;color:#922b21;border-left:4px solid #e74c3c;}
.hgp-total-bar{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--hgp-light);border-radius:8px;margin-top:10px;border:1px solid var(--hgp-border);}
.hgp-total-bar .total-label{font-size:14px;color:#555;}
.hgp-total-bar .total-amount{font-size:22px;font-weight:800;color:var(--hgp-primary);}
.hgp-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99999;align-items:center;justify-content:center;padding:20px;}
.hgp-modal-overlay.active{display:flex;}
.hgp-modal{background:#fff;border-radius:16px;max-width:460px;width:100%;padding:28px;position:relative;max-height:90vh;overflow-y:auto;}
.hgp-modal h3{margin:0 0 16px;color:var(--hgp-primary);font-size:18px;}
.hgp-modal-close{position:absolute;top:16px;right:18px;font-size:22px;cursor:pointer;background:none;border:none;color:#666;line-height:1;}
.hgp-pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0;}
.hgp-pay-method{padding:14px;border:2px solid var(--hgp-border);border-radius:10px;cursor:pointer;text-align:center;font-size:13px;font-weight:600;transition:.2s;background:#fff;}
.hgp-pay-method:hover,.hgp-pay-method.selected{border-color:var(--hgp-primary);background:rgba(30,58,95,.05);color:var(--hgp-primary);}
.hgp-pay-method .pay-icon{font-size:22px;display:block;margin-bottom:4px;}
.hgp-receipt-display{text-align:center;padding:16px 0;}
.hgp-receipt-display #hgp-receipt-qr{margin:16px auto;}
.hgp-receipt-code{font-family:monospace;font-size:24px;letter-spacing:4px;color:var(--hgp-primary);font-weight:700;margin-top:10px;}
.hgp-receipt-note{font-size:13px;color:#666;margin-top:8px;line-height:1.5;}
.hgp-receipt-amount{font-size:28px;font-weight:800;color:var(--hgp-green);margin:10px 0;}
.hgp-qr-wrap{display:inline-block;background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px rgba(0,0,0,.12);margin:10px auto;border:2px solid var(--hgp-border);}
#hgp-qr-code canvas,#hgp-qr-code img{display:block;margin:0 auto;}
.hgp-qr-guest-name{font-size:15px;font-weight:700;color:#1e3a5f;margin-top:10px;}
.hgp-qr-timer{font-family:monospace;font-size:13px;color:#888;margin-top:4px;}
.hgp-qr-timer .timer-critical{color:#e74c3c;font-weight:700;}
.hgp-qr-instructions{max-width:300px;margin:12px auto 0;font-size:13px;color:#666;line-height:1.5;}
.hgp-qr-refresh-btn{margin-top:12px;background:rgba(30,58,95,.08);color:#1e3a5f;border:1px solid rgba(30,58,95,.2);padding:8px 20px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;}
.hgp-live-dot{display:inline-block;width:8px;height:8px;background:var(--hgp-green);border-radius:50%;margin-right:4px;animation:hgp-pulse 2s ease-in-out infinite;}
.hgp-loading{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:hgp-spin .7s linear infinite;vertical-align:middle;}
@keyframes hgp-spin{to{transform:rotate(360deg);}}
@keyframes hgp-pulse{0%,100%{opacity:1;}50%{opacity:.3;}}
