:root{--text:#4b5563;--text-h:#111827;--muted:#6b7280;--bg:#f4f6f3;--surface:#fff;--card-bg:#fbf7ef;--input-bg:#fff;--border:#d9ded6;--border-strong:#a9b3a5;--accent:#0f766e;--stamp:#b45309;--notice:#e7f2ef;--success:#047857;--sans:Inter, ui-sans-serif, system-ui, "Segoe UI", Roboto, Arial, sans-serif;font-family:var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.45}*{min-width:0}body{margin:0}button,input,select{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:2px;outline:3px solid #0f766e38}h1,h2,p{margin:0}h1{color:var(--text-h);letter-spacing:0;font-size:clamp(34px,5vw,62px);line-height:.98}h2{color:var(--text-h);letter-spacing:0;font-size:24px;line-height:1.15}.app-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:28px 0 48px}.auth-shell{grid-template-columns:.85fr 1.15fr;align-items:center;gap:18px;width:min(1080px,100% - 32px);min-height:100svh;margin:0 auto;padding:32px 0;display:grid}.brand-panel{color:#fff;background:var(--accent);border-radius:8px;align-content:center;gap:16px;min-height:520px;padding:34px;display:grid}.brand-panel img{object-fit:contain;background:#fff;border-radius:8px;max-width:132px;max-height:132px;padding:10px}.brand-panel h1{color:#fff}.auth-panel{min-height:520px}.auth-tabs{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;display:grid}.auth-tabs button,.link-button,.secondary-button,.danger-button{border:1px solid var(--border);cursor:pointer;background:var(--surface);min-height:42px;color:var(--text-h);border-radius:8px}.auth-tabs button.active{border-color:var(--accent);background:var(--accent);color:#fff}.link-button{color:var(--accent);border:0;font-weight:750}.app-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:24px;min-height:154px;display:flex}.app-header h1{margin:0}.brand-title{align-items:center;gap:16px;display:flex}.brand-title img{object-fit:contain;border:1px solid var(--border);background:#fff;border-radius:8px;width:68px;height:68px}.eyebrow{color:var(--muted);letter-spacing:0;text-transform:uppercase;font-size:13px;font-weight:700}.header-reward{border:1px solid var(--border);background:var(--surface);border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:4px 10px;min-width:230px;padding:16px;display:grid}.header-reward svg{color:var(--accent);grid-row:span 2}.tabs{gap:8px;margin:22px 0;padding-bottom:2px;display:flex;overflow-x:auto}.tabs button,.lookup-row button,.primary-button,.stamp-button,.secondary-button,.danger-button{border:1px solid var(--border);background:var(--surface);color:var(--text-h);cursor:pointer;box-sizing:border-box;border-radius:8px;min-height:42px}.tabs button{white-space:nowrap;flex:none;justify-content:center;align-items:center;gap:8px;max-width:100%;padding:9px 14px;line-height:1.15;display:inline-flex}.tabs button svg,.primary-button svg,.secondary-button svg,.danger-button svg{flex:none}.tabs button.active,.primary-button{border-color:var(--accent);background:var(--accent);color:#fff}.primary-button:disabled{cursor:not-allowed;opacity:.55}.secondary-button,.danger-button{text-align:center;white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:9px 14px;line-height:1.15;display:inline-flex}.danger-button{color:#991b1b;background:#fff5f5;border-color:#fecaca;margin-top:18px}.content-grid{grid-template-columns:.9fr 1.1fr;align-items:start;gap:18px;display:grid}.panel,.loyalty-card,.empty-state{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:22px}.panel h2,.empty-state h2{margin-top:0}.form-stack,.settings-grid{gap:14px;display:grid}.two-cols{grid-template-columns:repeat(2,minmax(0,1fr))}.wide{grid-column:1/-1}label{color:var(--text-h);gap:7px;font-weight:650;display:grid}input,select{box-sizing:border-box;border:1px solid var(--border);background:var(--input-bg);width:100%;min-height:44px;color:var(--text-h);font:inherit;border-radius:8px;padding:0 12px}select{cursor:pointer}select:disabled{cursor:not-allowed;color:var(--muted);background:#f3f4f6}.primary-button{text-align:center;white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:9px 16px;font-weight:750;line-height:1.15;display:inline-flex}.lookup-row{grid-template-columns:1fr 46px;gap:8px;margin-top:16px;display:grid}.loyalty-card{background:var(--card-bg)}.reward-banner{color:#064e3b;background:#d1fae5;border:1px solid #a7f3d0;border-radius:8px;align-items:center;gap:10px;margin-bottom:18px;padding:12px 14px;font-weight:800;display:flex}.card-topline,.customer-summary,.reward-row,.qr-panel,.earned{align-items:center;gap:14px;display:flex}.card-topline{justify-content:space-between}.mini-logo{object-fit:contain;border:1px solid var(--border);background:#fff;border-radius:8px;width:56px;height:56px}.stamp-grid{grid-template-columns:repeat(var(--stamp-count), minmax(38px, 1fr));gap:10px;margin:26px 0;display:grid}.stamp-slot{aspect-ratio:1;border:1px dashed var(--border-strong);color:var(--muted);background:#ffffff9e;border-radius:999px;justify-content:center;align-items:center;font-weight:750;display:inline-flex}.stamp-slot.filled{border-style:solid;border-color:var(--stamp);color:#fff;background:var(--stamp)}.stamp-slot img{object-fit:contain;width:72%;height:72%}.reward-row{background:#ffffffa8;border-radius:8px;padding:14px}.reward-row div,.qr-panel div{display:grid}.qr-panel{border:1px solid var(--border);background:#ffffffb3;border-radius:8px;margin-top:18px;padding:14px}.qr-panel .customer-qr,.qr-placeholder{background:#fff;border-radius:8px;flex:0 0 138px;width:138px;height:138px}.qr-panel .customer-qr{aspect-ratio:1;object-fit:contain;image-rendering:pixelated;display:block}.pass-button{justify-self:start;margin-top:12px}.pass-message{color:#92400e;margin-top:8px;font-size:.9rem;line-height:1.35}.empty-state{text-align:center;min-height:320px;color:var(--muted);align-content:center;justify-items:center;display:grid}.empty-state.inline{border:0;min-height:260px;padding:0}.admin-actions{gap:14px;display:grid}.scanner{border:1px solid var(--border);border-radius:8px;margin-top:16px;overflow:hidden}#qr-reader{width:100%}.scanner-state,.status{background:var(--notice);color:var(--text-h);border-radius:8px;margin:14px 0 0;padding:12px 14px}.status.compact{margin-bottom:0}.admin-card{min-height:390px}.customer-summary{justify-content:space-between}.customer-summary h2{margin-bottom:0}.stamp-buttons{flex-shrink:0;align-items:center;gap:8px;display:flex}.stamp-button{border-color:var(--stamp);background:var(--stamp);color:#fff;justify-content:center;align-items:center;width:52px;height:52px;display:inline-flex}.stamp-button.minus{color:var(--muted);border-color:var(--border);background:0 0;width:40px;height:40px}.stamp-button.minus:disabled{opacity:.35;cursor:not-allowed}.stamp-button.minus:not(:disabled):hover{border-color:var(--border-strong);color:var(--text-h)}.progress-bar{background:var(--border);border-radius:999px;height:12px;margin:24px 0 10px;overflow:hidden}.progress-bar span{border-radius:inherit;background:var(--accent);height:100%;display:block}.big-count{color:var(--text-h);margin:0;font-size:42px;font-weight:800}.big-count span{color:var(--muted);font-size:16px}.earned{color:var(--success);margin-top:12px;font-weight:750}.event-list{gap:8px;margin-top:20px;display:grid}.event-list div{border-top:1px solid var(--border);grid-template-columns:42px 1fr auto;gap:10px;padding:10px 0;display:grid}.event-list time{color:var(--muted);font-size:13px}.settings-panel{max-width:1060px}.settings-layout{grid-template-columns:1fr auto;align-items:start;gap:36px;display:grid}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-grid .primary-button{grid-column:1/-1}.card-canvas-wrap{gap:10px;display:grid;position:sticky;top:20px}.card-canvas-wrap-label{letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin:0;font-size:11px;font-weight:700}.card-canvas{background:var(--canvas-bg,#0f766e);color:#fff;-webkit-user-select:none;user-select:none;border-radius:18px;gap:14px;width:260px;padding:18px 16px 16px;display:grid;box-shadow:0 10px 40px #00000038,0 2px 8px #0000001f}.card-canvas-header{align-items:center;gap:10px;display:flex}.card-canvas-logo{object-fit:contain;background:#ffffff26;border-radius:8px;flex-shrink:0;width:38px;height:38px}.card-canvas-logo-ph{opacity:.6;background:#ffffff26;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.card-canvas-title{flex-direction:column;gap:2px;min-width:0;display:flex}.card-canvas-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:800;line-height:1.2;overflow:hidden}.card-canvas-slogan{opacity:.75;white-space:nowrap;text-overflow:ellipsis;font-size:10px;line-height:1.3;overflow:hidden}.card-canvas-customer{flex-direction:column;gap:2px;display:flex}.card-canvas-field-label{letter-spacing:.09em;opacity:.65;font-size:9px;font-weight:700}.card-canvas-field-value{font-size:15px;font-weight:700}.card-canvas-stamps{flex-wrap:wrap;gap:5px;display:flex}.card-canvas-slot{color:#ffffff73;border:1.5px dashed #ffffff59;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:9px;font-weight:700;display:inline-flex}.card-canvas-slot.filled{background:var(--canvas-accent,#b45309);border:1.5px solid var(--canvas-accent,#b45309);color:#fff}.card-canvas-slot img{object-fit:contain;width:68%;height:68%}.card-canvas-footer{border-top:1px solid #ffffff2e;justify-content:space-between;align-items:center;padding-top:10px;font-size:12px;font-weight:600;display:flex}.card-canvas-goal{opacity:.65;font-size:10px;font-weight:400}.legal-text{color:var(--muted);grid-column:1/-1;margin:0;font-size:11px;line-height:1.5}.card-slogan{color:var(--muted);margin:0;font-size:13px;font-style:italic}.danger-panel{align-self:start}.admin-list{gap:10px;display:grid}.admin-list div{border-top:1px solid var(--border);gap:2px;padding:12px 0;display:grid}.admin-list small,.admin-list span,.muted{color:var(--muted)}.reports-view{gap:18px;display:grid}.report-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.metric-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;display:grid}.metric-card{border:1px solid var(--border);background:var(--surface);border-radius:8px;gap:4px;padding:16px;display:grid}.metric-card span,.metric-card small{color:var(--muted)}.metric-card strong{color:var(--text-h);font-size:30px;line-height:1}.reports-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:18px;display:grid}.wide-reports{grid-template-columns:1.2fr .8fr}.panel h3{color:var(--text-h);margin:0 0 14px;font-size:18px}.bar-list{gap:9px;display:grid}.bar-row{grid-template-columns:78px 1fr 44px;align-items:center;gap:10px;display:grid}.bar-row span,.bar-row strong{font-size:13px}.bar-row div{background:var(--border);border-radius:999px;height:10px;overflow:hidden}.bar-row i{border-radius:inherit;background:var(--accent);min-width:2px;height:100%;display:block}.compact-table,.report-table{gap:0;display:grid}.compact-table div,.report-table>div{border-top:1px solid var(--border);gap:8px;padding:10px 0;display:grid}.compact-table div{grid-template-columns:1.2fr .9fr 1fr}.compact-table span,.report-table span,.report-table small{color:var(--muted)}.report-table>div{grid-template-columns:minmax(170px,1.5fr) minmax(130px,1fr) 70px 70px 70px;align-items:center}.report-table-head span{color:var(--text-h);text-transform:uppercase;font-size:12px;font-weight:800}.report-table span:first-child{gap:2px;display:grid}.user-list{gap:0;max-height:560px;display:grid;overflow-y:auto}.user-list-item{border-top:1px solid var(--border);text-align:left;cursor:pointer;background:0 0;border-bottom:0;border-left:0;border-right:0;border-radius:0;justify-content:space-between;align-items:center;gap:12px;min-height:0;padding:12px 0;display:flex}.user-list-item:hover,.user-list-item.active{background:var(--notice);margin:0 -22px;padding-left:22px;padding-right:22px}.user-list-info{gap:2px;min-width:0;display:grid}.user-list-info span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.user-badges{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;gap:6px;display:flex}.badge{white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700}.badge-red{color:#991b1b;background:#fee2e2}.badge-yellow{color:#92400e;background:#fef3c7}.badge-neutral{background:var(--notice);color:var(--accent)}.user-actions{flex-wrap:wrap;gap:8px;margin-bottom:4px;display:flex}.user-actions .secondary-button,.user-actions .danger-button{flex:none;min-height:36px;padding:7px 12px;font-size:13px}.form-actions{gap:8px;display:flex}.admin-list-item{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:12px 0;display:flex}.admin-list-info{gap:2px;display:grid}.admin-list-info span,.admin-list-info small{color:var(--muted)}.admin-list-actions{flex-shrink:0;gap:6px;display:flex}.admin-list-actions .secondary-button,.admin-list-actions .danger-button{min-height:34px;padding:7px 10px}.toggle-label{border:1px solid var(--border);cursor:pointer;color:var(--text-h);border-radius:8px;grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:center;gap:2px 12px;padding:12px 14px;font-weight:650;display:grid}.toggle-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;min-height:0;accent-color:var(--accent);flex:0 0 18px;grid-area:1/2/3}.toggle-desc{color:var(--muted);font-size:12px;font-weight:400;line-height:1.4}.remember-label{color:var(--text);cursor:pointer;flex-direction:row;align-items:center;gap:8px;font-weight:400;display:flex}.remember-label input[type=checkbox]{cursor:pointer;width:16px;height:16px;min-height:0;accent-color:var(--accent);flex:0 0 16px}.password-field{position:relative}.password-field input{padding-right:46px}.password-eye{cursor:pointer;width:46px;color:var(--muted);background:0 0;border:0;justify-content:center;align-items:center;min-height:0;display:flex;position:absolute;top:0;bottom:0;right:0}.password-eye:hover{color:var(--accent)}.match-ok{color:var(--success);font-size:13px;font-weight:700}.match-fail{color:#ef4444;font-size:13px;font-weight:700}.audit-table-wrap{overflow-x:auto}.audit-table{border-collapse:collapse;width:100%;font-size:13px}.audit-table th{text-align:left;border-bottom:2px solid var(--border);color:var(--muted);white-space:nowrap;padding:8px 10px;font-weight:600}.audit-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:7px 10px}.audit-table tbody tr:last-child td{border-bottom:none}.audit-date{white-space:nowrap;color:var(--muted);font-size:12px}.audit-name{max-width:160px}.audit-name small{color:var(--muted);font-size:11px}.audit-ip{color:var(--muted);white-space:nowrap;font-size:12px}.audit-action{background:var(--notice);color:var(--success);border-radius:4px;padding:2px 7px;font-size:12px;font-weight:600;display:inline-block}.audit-action-stamp_remove,.audit-action-user_block,.audit-action-user_delete,.audit-action-admin_delete{color:#b91c1c;background:#fee2e2}.audit-action-reward_redeem,.audit-action-admin_create,.audit-action-admin_update{color:#6d28d9;background:#ede9fe}@media (width<=700px){.settings-layout{grid-template-columns:1fr}.card-canvas-wrap{order:-1;position:static}.card-canvas{width:100%;max-width:300px;margin:0 auto}}@media (width<=840px){.app-shell{width:min(100% - 20px,1180px);padding-top:12px}.app-header,.content-grid,.settings-grid,.auth-shell,.two-cols,.reports-grid,.wide-reports,.metric-grid{grid-template-columns:1fr;display:grid}.brand-panel,.auth-panel{min-height:0}.app-header{min-height:0;padding-bottom:18px}.stamp-grid{grid-template-columns:repeat(5,1fr)}.qr-panel{flex-direction:column;align-items:flex-start}.qr-panel .customer-qr,.qr-placeholder{aspect-ratio:1;flex-basis:auto;width:min(180px,100%);height:auto}.event-list div{grid-template-columns:38px 1fr}.event-list time{grid-column:2}.report-header{flex-direction:column;align-items:stretch}.compact-table div,.report-table>div{grid-template-columns:1fr}.report-table-head{display:none!important}}
