@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap";:root{--bg-base: #f8fafc;--bg-soft: #ffffff;--panel: #ffffff;--line: #e4ebf3;--text: #1f2937;--text-muted: #64748b;--mint: #0f4c81;--mint-soft: #eef5ff;--sunset: #f68b1f;--sunset-soft: #fff4e8;--sky: #0f4c81;--sky-soft: #eef4ff;--danger: #dc2626;--info: #0f4c81;--shadow: 0 10px 28px rgba(15, 23, 42, .08)}*{box-sizing:border-box}img,video{max-width:100%}html,body{width:100%}body{margin:0;min-height:100vh;font-family:Roboto,Avenir Next,sans-serif;color:var(--text);overflow-x:hidden;background:var(--bg-base)}#root{min-height:100vh}h1,h2,h3,p{margin:0}.app-shell{width:min(1220px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 2.9rem}.app-shell.customer-shell{width:100%;max-width:none;padding-left:1rem;padding-right:1rem}.app-shell--narrow{width:min(760px,calc(100% - 1.6rem));padding-top:4rem}.app-shell--auth{width:min(980px,calc(100% - 1.8rem));padding-top:2.2rem}.hero,.dashboard-header{border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--shadow);padding:1.45rem}.hero{animation:rise-in .45s ease both}.dashboard-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;animation:rise-in .45s ease both}.dashboard-header>div{min-width:0}.customer-header{display:flex;flex-direction:column;gap:.45rem;margin-bottom:.1rem}.customer-header__top{display:flex;align-items:center;gap:.72rem;min-height:62px}.customer-header__logo{width:min(102px,28vw);height:auto;display:block;flex-shrink:0}.customer-header__greeting{margin:0;font-size:clamp(2rem,5vw,2rem);font-weight:700;line-height:1.2;min-width:0;overflow-wrap:anywhere}.customer-header__logout{width:auto;flex-shrink:0}.customer-header__logout--mobile,.customer-header__mobile-actions{display:none}.customer-tabs{display:flex;align-items:center;gap:.44rem;min-width:0}.customer-tabs--desktop{margin-top:.2rem;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.52rem}.customer-tabs--desktop .customer-mobile-nav__button{min-height:64px;padding:.56rem;justify-content:center}.customer-tabs--top{margin-bottom:.25rem}.admin-shell{display:grid;grid-template-columns:250px minmax(0,1fr);gap:1rem;align-items:start}.admin-workspace{min-width:0}.admin-sidebar{position:sticky;top:1rem;border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:var(--shadow);padding:1rem;display:grid;gap:.9rem}.admin-sidebar__brand{border:1px solid var(--line);border-radius:12px;background:#fff;padding:.86rem}.admin-sidebar__brand h2{margin:.16rem 0 0;font-size:1.1rem}.admin-sidebar__nav{display:grid;gap:.42rem}.admin-sidebar__nav .admin-nav__button{min-height:54px}.admin-sidebar__footer{margin-top:.45rem;padding-top:.35rem;border-top:1px solid #edf2f7}.settings-subnav{margin-top:.65rem;display:flex;flex-wrap:wrap;gap:.44rem}.settings-subnav--top{margin-top:0;margin-bottom:.85rem}.admin-nav__button{width:100%;border-radius:14px;border:1px solid var(--line);background:#fff;padding:.66rem;display:flex;align-items:center;gap:.58rem;text-align:left;cursor:pointer;font:inherit;transition:transform .12s ease,box-shadow .14s ease,border-color .14s ease}.admin-nav__button:hover{transform:translateY(-1px);box-shadow:0 8px 20px #0f172a14}.admin-nav__button--members{color:var(--sky)}.admin-nav__button--dashboard{color:#2563eb}.admin-nav__button--rewards{color:#b45309}.admin-nav__button--redemptions{color:#1d4ed8}.admin-nav__button--transactions{color:#1e40af}.admin-nav__button--tiers{color:#a16207}.admin-nav__button--settings{color:#0369a1}.admin-nav__button--logs{color:#475569}.admin-nav__button--active{border-color:#bfdbfe;box-shadow:0 0 0 2px #2563eb26}.admin-nav__icon{width:33px;height:33px;border-radius:10px;border:1px solid #e8eef6;background:#f8fafc;display:grid;place-items:center;flex-shrink:0}.admin-nav__icon svg{width:19px;height:19px;display:block}.admin-nav__label{font-size:.84rem;font-weight:700;line-height:1.2}.secondary-button.admin-sidebar-logout{width:auto;min-height:38px;flex-shrink:0;padding:.5rem .76rem;white-space:nowrap}.admin-shortcuts{margin-bottom:.85rem;display:flex;align-items:center;gap:.58rem;justify-content:space-between}.admin-shortcut-button{width:auto;display:inline-flex;align-items:center;justify-content:center;gap:.44rem}.admin-shortcut-button__icon{width:18px;height:18px;display:inline-flex}.admin-shortcut-button__icon svg{width:18px;height:18px;display:block}.admin-menu-toggle{display:none;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line);border-radius:10px;background:#fff;color:#475569;cursor:pointer;padding:0;transition:transform .12s ease,opacity .12s ease}.admin-menu-toggle:hover{transform:translateY(-1px)}.admin-menu-toggle:disabled{opacity:.55;cursor:not-allowed;transform:none}.admin-menu-toggle svg{width:20px;height:20px;display:block}.admin-mobile-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#0f172a57;display:grid;justify-items:start}.admin-mobile-drawer{width:min(84vw,320px);height:100%;border-right:1px solid var(--line);background:#fff;box-shadow:12px 0 30px #0f172a29;padding:.88rem;display:grid;grid-template-rows:auto 1fr auto;gap:.72rem;overflow-y:auto}.admin-mobile-drawer__head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.admin-mobile-drawer__head h3{margin:.16rem 0 0;font-size:1.1rem}.admin-mobile-drawer__close{border:1px solid var(--line);border-radius:9px;background:#fff;color:#475569;font:inherit;font-weight:700;font-size:.78rem;padding:.35rem .58rem;cursor:pointer}.admin-mobile-drawer__close:hover{transform:translateY(-1px)}.admin-mobile-drawer__nav{display:grid;gap:.42rem}.admin-mobile-drawer__nav .admin-nav__button{min-height:52px}.admin-mobile-drawer__footer{padding-top:.3rem}.customer-home-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem;margin-bottom:.35rem}.customer-home-heading__left{display:flex;flex-direction:column;min-width:0}.customer-home-heading__right{margin-left:auto;display:flex;align-items:flex-start;flex-shrink:0}.customer-home-day{margin:0;letter-spacing:.02em;color:var(--sunset);font-size:clamp(1rem,1.6vw,1.1rem);font-weight:700}.customer-home-name{margin:.08rem 0 0;font-size:clamp(2rem,6vw,2rem);line-height:.98;font-weight:700;color:#1f1d29;overflow-wrap:anywhere}.secondary-button.customer-home-logout{width:auto!important;flex-shrink:0!important;min-height:34px;padding:.4rem .62rem}.customer-mobile-nav{display:none}.customer-mobile-nav__button{width:100%;border-radius:14px;border:1px solid var(--line);background:#fff;padding:.72rem;display:flex;align-items:center;gap:.64rem;text-align:left;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.customer-mobile-nav__button:hover{transform:translateY(-1px)}.customer-mobile-nav__button--home{color:var(--sky)}.customer-mobile-nav__button--pets{color:#b45309}.customer-mobile-nav__button--redemptions{color:#1d4ed8}.customer-mobile-nav__button--activity{color:#1e40af}.customer-mobile-nav__button--active{border-color:#bfdbfe;box-shadow:0 0 0 2px #2563eb26}.customer-mobile-nav__icon{width:34px;height:34px;border-radius:10px;border:1px solid #e8eef6;background:#f8fafc;display:grid;place-items:center;flex-shrink:0}.customer-mobile-nav__icon svg{width:20px;height:20px;display:block}.customer-mobile-nav__label{font-size:.88rem;font-weight:700;line-height:1.2}.hero__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--mint);font-size:.78rem;font-weight:700}.hero h1,.dashboard-header h1{margin-top:.42rem;font-size:clamp(1.45rem,2.3vw,2.2rem)}.hero__copy{margin-top:.7rem;color:var(--text-muted);overflow-wrap:anywhere}.auth-grid,.layout-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:.9rem;margin-top:.9rem}.auth-single{width:100%;margin-top:.8rem}.panel--auth{grid-column:auto;width:min(500px,100%);margin:0 auto}.auth-page{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:1rem 2rem}.auth-logo-wrap{display:flex;justify-content:center}.auth-logo{width:min(175px,50vw);height:auto;display:block}.auth-admin-dot{position:fixed;right:18px;bottom:18px;width:14px;height:14px;border:0;border-radius:50%;background:var(--sky);box-shadow:0 0 0 3px #0f4c8133;cursor:pointer;transition:transform .14s ease,opacity .14s ease}.auth-admin-dot:hover{transform:scale(1.08)}.auth-admin-dot:disabled{opacity:.45;cursor:not-allowed;transform:none}.panel{grid-column:span 6;border:1px solid var(--line);border-radius:18px;background:var(--panel);box-shadow:var(--shadow);padding:1.15rem;animation:rise-in .52s ease both;min-width:0}.panel--wide{grid-column:span 8}.customer-shell .panel--wide{grid-column:1 / -1}.customer-home-grid{grid-template-columns:minmax(0,30%) minmax(0,70%)}.customer-home-grid .panel--home-overview{grid-column:1}.customer-home-grid .panel--home-catalog{grid-column:2}.customer-pets-grid{grid-template-columns:minmax(0,62%) minmax(0,38%)}.customer-pets-grid .panel--pets-list{grid-column:1}.customer-pets-grid .panel--pets-form{grid-column:2;align-self:start}.panel--compact{grid-column:span 4}.panel--half{grid-column:span 6}.panel--full{grid-column:1 / -1}.panel__title{font-size:1.1rem}.panel__header{display:flex;justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:.45rem}.panel__header--members{flex-wrap:wrap}.members-header-actions{margin-left:auto;display:flex;flex-wrap:wrap;gap:.45rem;justify-content:flex-end}.members-header-actions .members-header-button{width:auto;min-height:38px;white-space:nowrap}.stack-form{display:flex;flex-direction:column;gap:.55rem;margin-top:.72rem}.field-label{color:var(--text-muted);font-size:.78rem;margin-top:.2rem}.text-field{width:100%;border:1px solid #d7e1ec;border-radius:12px;background:var(--bg-soft);font:inherit;padding:.66rem .76rem}.text-field:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f624}.text-field--textarea{min-height:94px;resize:vertical}.primary-button,.secondary-button,.text-button,.tab-button{border:0;font:inherit;border-radius:10px;cursor:pointer;transition:transform .12s ease,opacity .12s ease}.primary-button,.secondary-button{padding:.66rem .9rem;font-weight:600}.primary-button{color:#fff;background:#f28b44}.secondary-button{color:#fff;background:var(--sky)}.text-button{padding:0;background:transparent;color:#2d68a1;text-decoration:underline}.text-button:disabled{opacity:.45;cursor:not-allowed;text-decoration:none}.primary-button:hover,.secondary-button:hover,.tab-button:hover{transform:translateY(-1px);box-shadow:0 8px 16px #0f172a26}.primary-button:disabled,.secondary-button:disabled,.tab-button:disabled{opacity:.56;cursor:not-allowed;transform:none}.helper-text{margin-top:.2rem;font-size:.82rem;color:var(--text-muted);line-height:1.45}.form-error{color:var(--danger);font-size:.82rem}.admin-form-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:82;background:#0f172a6b;display:grid;place-items:center;padding:1rem}.admin-form-modal{width:min(100%,560px);max-height:calc(100vh - 2rem);overflow-y:auto;border-radius:16px;border:1px solid var(--line);background:#fff;padding:1.05rem;box-shadow:0 16px 34px #0f172a2e}.admin-form-modal--scan{width:min(100%,940px)}.admin-form-modal--import-transactions{width:min(100%,980px)}.import-transactions-body{margin-top:.55rem;display:grid;gap:.52rem}.import-transactions-note{border:1px solid #d7e5f8;border-radius:12px;background:#f4f8ff;color:#295582;padding:.62rem .7rem;display:grid;gap:.34rem;font-size:.84rem;line-height:1.45}.import-transactions-note p{margin:0}.admin-form-modal__head{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.admin-form-modal__close{border:1px solid var(--line);border-radius:9px;background:#fff;color:#475569;font:inherit;font-size:.8rem;font-weight:700;padding:.34rem .6rem;cursor:pointer}.admin-form-modal__close:hover{transform:translateY(-1px)}.admin-form-modal .stack-form{margin-top:.45rem}.import-transactions-upload-label{margin-top:.22rem;font-size:.95rem;font-weight:700;color:#3f3850}.import-transactions-file-meta{margin-top:.05rem}.import-transactions-action-row{margin-top:.2rem;display:flex;align-items:center;justify-content:space-between;gap:.62rem;flex-wrap:wrap}.import-transactions-action-row .secondary-button,.import-transactions-action-row .primary-button{width:auto}.admin-form-modal__actions{margin-top:.7rem;display:flex;gap:.52rem;justify-content:flex-end;flex-wrap:wrap}.admin-form-modal__actions .primary-button,.admin-form-modal__actions .secondary-button{width:auto}.import-transactions-summary{margin-top:.18rem}.redemption-scan-split{margin-top:.65rem;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:.88rem;align-items:start}.redemption-scan-left,.redemption-scan-right{min-width:0}.redemption-scan-right .stack-form{margin-top:.35rem}.camera-controls{margin-top:.6rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.camera-preview{margin-top:.6rem;width:100%;border-radius:12px;border:1px solid #d7cec0;background:#111}.banner-error,.banner-info{margin-top:.85rem;border-radius:14px;border:1px solid;padding:.74rem .95rem}.banner-error{background:#fff7f7;color:var(--danger);border-color:#fecaca}.banner-info{background:#f4f8ff;color:var(--info);border-color:#d7e5f8}.stats-grid{margin-top:.9rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem}.stat-card{border-radius:16px;border:1px solid var(--line);background:#fff;padding:1.02rem;min-height:128px;animation:rise-in .5s ease both}.stat-card--mint{background:linear-gradient(180deg,#fff,#f5f9ff);border-color:#cfe0fb}.stat-card--sunset{background:linear-gradient(180deg,#fff,#fff8f2);border-color:#f5dbc9}.stat-card--sky{background:linear-gradient(180deg,#fff,#f5f9ff);border-color:#cfe0fb}.stat-card__label{font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.stat-card__value{margin-top:.4rem;font-size:1.75rem}.stat-card__detail{margin-top:.45rem;color:#4f4859;font-size:.85rem}.operations-kpi-grid{margin-top:.75rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.58rem}.operations-kpi-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:.68rem}.operations-kpi-card__label{margin:0;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:#6a6074}.operations-kpi-card__value{margin:.34rem 0 0;font-size:1.5rem;font-weight:700;color:#2f2a39}.operations-summary-list{margin-top:.5rem;display:grid;gap:.34rem}.operations-summary-list p{margin:0;color:#5d566c;font-size:.86rem}.operations-summary-list strong{color:#2f2a39}.reward-details-split{margin-top:.5rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.62rem}.reward-details-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:.68rem;display:grid;gap:.34rem}.reward-details-card p{margin:0;color:#5d566c;font-size:.86rem}.reward-details-card strong{color:#2f2a39}.member-details-split{margin-top:.5rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.62rem}.member-details-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:.68rem;display:grid;gap:.34rem}.member-details-card p{margin:0;color:#5d566c;font-size:.86rem}.member-details-card strong{color:#2f2a39}.member-history-heading{margin-top:1rem}.user-details-split{margin-top:.5rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.62rem}.user-details-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:.68rem;display:grid;gap:.34rem}.user-details-card p{margin:0;color:#5d566c;font-size:.86rem}.user-details-card strong{color:#2f2a39}.user-history-heading{margin-top:1rem}.settings-title-with-tooltip{display:inline-flex;align-items:center;gap:.44rem}.help-tooltip{position:relative;display:inline-flex;align-items:center}.help-tooltip__trigger{width:22px;height:22px;border-radius:999px;border:1px solid var(--line);background:#fff;color:#475569;font:inherit;font-size:.82rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.help-tooltip__content{position:absolute;left:0;top:calc(100% + .42rem);z-index:2;width:min(420px,78vw);border:1px solid var(--line);border-radius:12px;background:#fff;box-shadow:0 10px 24px #0f172a24;padding:.54rem .62rem;font-size:.78rem;line-height:1.35;color:#5a5167;opacity:0;transform:translateY(4px);pointer-events:none;transition:opacity .12s ease,transform .12s ease}.help-tooltip:hover .help-tooltip__content,.help-tooltip__trigger:focus+.help-tooltip__content{opacity:1;transform:translateY(0)}.sms-template-grid{margin-top:.7rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.66rem}.sms-template-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:.78rem;display:grid;gap:.5rem}.sms-template-card h3{margin:0;font-size:1rem}.sms-template-card__head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.sms-template-card__toggle{display:inline-flex;align-items:center;gap:.34rem;font-size:.8rem;color:#5d566c}.reward-tier-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.35rem .5rem}.customer-home-points{margin-top:.8rem;display:grid;gap:.72rem}.customer-home-points__main{border:1px solid #d4e3fb;border-radius:16px;background:linear-gradient(180deg,#fff,#f5f9ff);padding:1.18rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.34rem;text-align:center}.customer-home-points__main--sky{border-color:#d4e3fb;background:linear-gradient(180deg,#fff,#f5f9ff)}.customer-home-points__main--mint{border-color:#c8e8da;background:linear-gradient(180deg,#fff,#eefaf4)}.customer-home-points__main--sunset{border-color:#f2ccb2;background:linear-gradient(180deg,#fff,#fff4e8)}.customer-home-points__main--gold{border-color:#f0d88a;background:linear-gradient(180deg,#fffef8,#fff7d9)}.customer-home-points__label{margin:0;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:#4e6480}.customer-home-points__tier{margin:0;display:inline-flex;align-items:center;justify-content:center;padding:.16rem .56rem;border-radius:999px;border:1px solid #c4d7f5;background:#eef4ff;font-size:.74rem;font-weight:700;letter-spacing:.03em;color:#1f4f82}.customer-home-points__tier--sky{border-color:#c4d7f5;background:#eef4ff;color:#1f4f82}.customer-home-points__tier--mint{border-color:#c8e8da;background:#eefaf4;color:#2f6d4c}.customer-home-points__tier--sunset{border-color:#f2ccb2;background:#fff4e8;color:#8a4e25}.customer-home-points__tier--gold{border-color:#f0d88a;background:#fff7d9;color:#8a6200}.customer-home-points__reserved-badge{display:inline-flex;align-items:center;justify-content:center;margin-top:.06rem;margin-bottom:.08rem;padding:.2rem .5rem;border-radius:999px;border:1px solid #c8c0b0;background:#fff6dd;color:#7d5d1d;font-size:.72rem;font-weight:600;line-height:1;white-space:nowrap}.customer-home-points__value{margin:0;font-size:clamp(2.1rem,6vw,2.8rem);line-height:1.03;font-weight:700;color:var(--sky)}.customer-home-points__detail{margin:0;color:#5e728c;font-size:.86rem}.tier-progress{width:100%;margin-top:.46rem;display:grid;gap:.3rem}.tier-progress__head{display:flex;align-items:center;justify-content:space-between;gap:.45rem;font-size:.76rem;color:#45607c;font-weight:600}.tier-progress__track{width:100%;height:9px;border-radius:999px;background:#e6eefb;overflow:hidden}.tier-progress__fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#f68b1f,#ffb356);transition:width .22s ease}.tier-progress--sky .tier-progress__head,.tier-progress--sky .tier-progress__meta{color:#45607c}.tier-progress--sky .tier-progress__track{background:#e6eefb}.tier-progress--sky .tier-progress__fill{background:linear-gradient(90deg,#0f4c81,#4d8fd4)}.tier-progress--mint .tier-progress__head,.tier-progress--mint .tier-progress__meta{color:#2f6d4c}.tier-progress--mint .tier-progress__track{background:#dff2e7}.tier-progress--mint .tier-progress__fill{background:linear-gradient(90deg,#2f8f63,#7fc8a2)}.tier-progress--sunset .tier-progress__head,.tier-progress--sunset .tier-progress__meta{color:#8a4e25}.tier-progress--sunset .tier-progress__track{background:#f7e4d6}.tier-progress--sunset .tier-progress__fill{background:linear-gradient(90deg,#f68b1f,#ffb356)}.tier-progress--gold .tier-progress__head,.tier-progress--gold .tier-progress__meta{color:#8a6200}.tier-progress--gold .tier-progress__track{background:#f7ebc2}.tier-progress--gold .tier-progress__fill{background:linear-gradient(90deg,#c99611,#f0d36b)}.tier-progress__meta{margin:0;font-size:.76rem;color:#5e728c}.tier-progress__perks{margin-top:.2rem;display:grid;gap:.42rem}.tier-perk-card{border:1px solid #d4e3fb;background:#fff;border-radius:12px;padding:.62rem .66rem;text-align:left}.tier-perk-card--sky{border-color:#c4d7f5;background:#f5f9ff}.tier-perk-card--mint{border-color:#c8e8da;background:#eefaf4}.tier-perk-card--sunset{border-color:#f2ccb2;background:#fff4e8}.tier-perk-card--gold{border-color:#f0d88a;background:#fff8df}.tier-perk-card__label{margin:0;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:#3f5670;font-weight:700}.tier-perk-card__list{margin:.38rem 0 0;padding-left:1rem;display:grid;gap:.22rem}.tier-perk-card__list li{color:#4f637b;font-size:.74rem;line-height:1.35}.customer-home-points__bottom{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.68rem}.customer-home-points__mini{border-radius:12px;border:1px solid transparent;padding:.82rem}.customer-home-points__mini--sunset{background:var(--sunset-soft);border-color:#f2ccb2}.customer-home-points__mini--sky{background:var(--sky-soft);border-color:#c4d7f5}.customer-home-points__mini--mint{background:#f5f9ff;border-color:#d4e3fb}.customer-home-points__mini--violet{background:#f2f7ff;border-color:#d7e5fb}.customer-home-points__mini-value{margin:.3rem 0 0;font-size:1.5rem;font-weight:700}.customer-home-qr-banner{display:flex;align-items:center;justify-content:space-between;gap:.58rem;flex-wrap:wrap}.customer-home-qr-banner .text-button{padding:.18rem .15rem;color:#1d5f98}.reward-catalog-filters{margin-top:.7rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;align-items:end}.reward-catalog-filter{display:grid;gap:.28rem}.reward-tier-group{margin-top:.88rem}.reward-tier-group__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.reward-tier-group__title{margin:0}.reward-tier-group__count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 .5rem;border-radius:999px;border:1px solid var(--line);background:#fff;color:#5d566c;font-size:.78rem;font-weight:700}.reward-grid{margin-top:.75rem;display:grid;gap:.65rem;grid-template-columns:repeat(3,minmax(0,1fr))}.reward-card{border:1px solid var(--line);background:#fff;border-radius:12px;padding:.9rem;display:flex;flex-direction:column;gap:.82rem}.reward-card h3{font-size:1rem}.reward-card p{margin-top:.24rem;color:var(--text-muted);font-size:.84rem}.reward-card__top-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.45rem}.reward-card__badges{display:flex;flex-direction:column;align-items:flex-end;gap:.28rem;margin-left:auto;flex-shrink:0}.reward-card__name{flex:1 1 auto;min-width:0;margin-top:0;margin-bottom:0;line-height:1.2;overflow-wrap:anywhere}.reward-card__credits{display:inline-flex;align-items:center;justify-content:center;padding:.18rem .56rem;border-radius:999px;border:1px solid #d4e3fb;background:#f5f9ff;color:#1f4f82;font-size:.75rem;font-weight:700;line-height:1.1;white-space:nowrap}.reward-card__tag{display:inline-flex;align-items:center;justify-content:center;padding:.16rem .45rem;border-radius:999px;border:1px solid #d4e3fb;background:#f5f9ff;color:#1f5185;font-size:.68rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.reward-card__meta{margin-top:.2rem}.reward-card__chips{margin-top:0;display:flex;flex-wrap:wrap;gap:.36rem}.reward-card__footer .reward-card__chips{margin-top:.08rem}.reward-card__progress{margin-top:0;display:grid;gap:.22rem}.reward-card__progress-head{display:flex;align-items:center;justify-content:space-between;gap:.45rem;color:#4b6581;font-size:.73rem;font-weight:600}.reward-card__progress-track{width:100%;height:8px;border-radius:999px;background:#e6eefb;overflow:hidden}.reward-card__progress-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#f68b1f,#ffb356);transition:width .22s ease}.reward-card__progress-note{margin:0;color:#607693;font-size:.66rem;font-weight:500}.reward-card .reward-card__progress-note{margin-top:0}.reward-card__divider{margin:0;border:0;border-top:1px solid #e6edf7}.reward-card__chip{display:inline-flex;align-items:center;max-width:100%;padding:.18rem .48rem;border-radius:999px;border:1px solid var(--line);background:#fff;color:#5f5668;font-size:.72rem;font-weight:600;line-height:1.15;overflow-wrap:anywhere}.reward-card__chip--condition{border-color:#f9dbc6;background:#fff7f2;color:#8a4e25}.reward-card__chip--limit{border-color:#d4e3fb;background:#f5f9ff;color:#295582}.reward-card__chip--tier{border-color:#d4e3fb;background:#f5f9ff;color:#1f4f82}.reward-card__chip--default{border-color:var(--line);background:#fff;color:#5d566c}.reward-card__warning{margin:0;color:#934727;font-size:.78rem;font-weight:500}.reward-card__footer{display:flex;flex-direction:column;align-items:stretch;gap:.34rem;margin-top:auto}.reward-card__action{width:100%}.qr-card{margin-top:.9rem;border:1px solid var(--line);background:#fff;border-radius:14px;padding:.9rem;display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.token-label{font-family:Courier New,Courier,monospace;font-size:.8rem;color:#475569;background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:.35rem .46rem;overflow-wrap:anywhere}.qr-image{width:176px;height:176px;border:1px solid var(--line);border-radius:10px;background:#fff}.list-wrap{margin-top:.8rem}.subheading{font-size:.96rem;margin-bottom:.4rem}.reward-history-heading{margin-top:.9rem}.plain-list{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}.list-item{border:1px solid #e8dfd4;background:#fcf8f1;border-radius:10px;padding:.56rem .65rem;display:grid;gap:.18rem;font-size:.85rem}.pets-top-list{margin-top:.72rem}.pets-title{font-size:clamp(1.28rem,2.4vw,1.6rem)}.pet-form-title{font-size:clamp(1.08rem,2vw,1.26rem)}.pet-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.66rem}.pet-card{border:1px solid var(--line);background:#fff;border-radius:12px;padding:.76rem;display:flex;flex-direction:column;gap:.35rem}.pet-card h3{margin:0;font-size:1rem}.pet-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.pet-card__details{display:grid;gap:.18rem}.pet-card__details p{margin:0;color:#4f4859;font-size:.84rem}.pet-card__detail-row{display:grid;grid-template-columns:72px 1fr;gap:.32rem;align-items:baseline}.pet-card__label{color:#3f3850;font-weight:800}.pet-card__value{color:#475569;overflow-wrap:anywhere}.pet-card__actions{margin-left:auto;display:flex;align-items:center;gap:.36rem;flex-shrink:0}.pet-icon-button{width:30px;height:30px;border:1px solid var(--line);background:#fff;border-radius:8px;display:grid;place-items:center;color:#3f6d9f;cursor:pointer}.pet-icon-button svg{width:16px;height:16px;display:block}.pet-icon-button:disabled{opacity:.45;cursor:not-allowed}.pet-icon-button--danger{color:var(--danger);border-color:#efc0c0;background:#fff5f5}.pet-form-block{margin-top:1rem;border-top:1px solid #edf2f7;padding-top:.82rem}.pet-form-actions{margin-top:.15rem;display:flex;gap:.52rem;flex-wrap:wrap}.pet-form-actions .primary-button,.pet-form-actions .secondary-button{width:auto}.table-wrap{margin-top:.75rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;min-width:700px;border-collapse:collapse}.data-table th,.data-table td{border-bottom:1px solid #eef2f7;text-align:left;padding:.58rem .4rem;font-size:.88rem}.data-table th{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.72rem}.table-subtext{color:var(--text-muted);font-size:.78rem}.tx-table{min-width:760px;table-layout:fixed}.tx-table .tx-col-date{width:16%;min-width:148px;white-space:nowrap}.tx-table .tx-col-member{width:18%;min-width:168px}.tx-table .tx-col-type{width:12%;min-width:108px;white-space:nowrap}.tx-table .tx-col-staff{width:13%;min-width:118px;white-space:nowrap}.tx-table .tx-col-points{width:8%;min-width:84px;white-space:nowrap}.tx-table .tx-col-note{width:33%;min-width:220px;white-space:normal;overflow-wrap:anywhere}.table-actions{display:inline-flex;align-items:center;gap:.34rem;flex-wrap:wrap}.table-action-button{border:1px solid var(--line);border-radius:8px;background:#fff;color:#3f3850;font:inherit;font-size:.76rem;font-weight:700;line-height:1;padding:.32rem .52rem;cursor:pointer}.table-action-button:hover{transform:translateY(-1px)}.table-action-button:disabled{opacity:.45;cursor:not-allowed;transform:none}.table-action-button--danger{border-color:#efc0c0;background:#fff1f1;color:#a03939}.table-empty{color:var(--text-muted);text-align:center}.mobile-record-list{display:none}.mobile-hide-table{display:block}.mobile-record-card{border:1px solid var(--line);background:#fff;border-radius:12px;padding:.72rem;display:grid;gap:.34rem}.mobile-record-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.mobile-record-card__title{margin:0;font-size:.98rem;color:#2f2a39}.mobile-record-card__meta{margin:0;color:#5d566c;font-size:.84rem}.mobile-record-card__action{justify-self:flex-start}.show-qr-button{display:inline-flex;align-items:center;justify-content:center;gap:.32rem;border:0;border-radius:9px;background:var(--sky);color:#fff;font:inherit;font-size:.8rem;font-weight:700;padding:.4rem .62rem;cursor:pointer;text-align:center;transition:transform .12s ease,opacity .12s ease}.show-qr-button:hover{transform:translateY(-1px)}.show-qr-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.show-qr-button__icon{width:16px;height:16px;display:inline-flex}.show-qr-button__icon svg{width:16px;height:16px;display:block}.mobile-record-card__type{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.14rem .44rem;font-size:.7rem;text-transform:capitalize;letter-spacing:.04em;color:#5f5567;font-weight:700;white-space:nowrap}.mobile-record-card__points{margin:0;font-size:.96rem}.qr-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;background:#0f172a6b;display:grid;place-items:center;padding:1rem}.qr-modal{width:min(100%,420px);border-radius:16px;border:1px solid var(--line);background:#fff;padding:.9rem;display:grid;gap:.48rem;box-shadow:0 16px 34px #0f172a2e}.qr-modal .qr-image{display:block;margin-inline:auto}.qr-modal__head{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.qr-modal__head h3{margin:0;font-size:1rem;color:var(--text)}.qr-modal__close{border:1px solid var(--line);border-radius:9px;background:#fff;color:#475569;font:inherit;font-size:.8rem;font-weight:700;padding:.34rem .6rem;cursor:pointer}.qr-modal__close:hover{transform:translateY(-1px)}.qr-modal__actions{margin-top:.24rem;display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.qr-modal__actions .primary-button,.qr-modal__actions .secondary-button{width:auto}.status-pill{display:inline-flex;align-items:center;border-radius:999px;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .5rem}.status-pill--pending{background:#fff2ca;color:#816001}.status-pill--approved{background:#dff3e5;color:#0d7b45}.status-pill--cancelled{background:#f9dfe1;color:#a92f36}.status-pill--active{background:#dff3e5;color:#0d7b45}.status-pill--inactive{background:#f3f6fb;color:#475569}.status-pill--success{background:#dff3e5;color:#0d7b45}.status-pill--failed{background:#f9dfe1;color:#a92f36}.status-pill--skipped{background:#f3f6fb;color:#475569}.tx-type{text-transform:capitalize}.points-positive{color:#118247;font-weight:700}.points-negative{color:#b93d3d;font-weight:700}.tab-nav{margin-top:.9rem;display:flex;flex-wrap:wrap;gap:.48rem}.tab-button{padding:.5rem .84rem;background:#fff;color:#64748b;border:1px solid var(--line);min-height:40px;white-space:nowrap}.tab-button--active{background:#fff;color:#1f2937;border-color:#bfdbfe;box-shadow:0 0 0 2px #2563eb24}.logs-subnav{margin-top:.65rem}.logs-filters{margin-top:.72rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.58rem;align-items:end}.logs-filter-field{min-width:0}.logs-filter-field .field-label{margin-top:0;margin-bottom:.2rem;display:block}.logs-filter-actions{margin-top:.28rem}.logs-summary{margin-top:.3rem}.empty-state{color:var(--text-muted);line-height:1.5}@keyframes rise-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1040px){.admin-shell{grid-template-columns:220px minmax(0,1fr);gap:.82rem}.auth-grid,.layout-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.panel,.panel--wide,.panel--compact,.panel--half{grid-column:span 6}.stats-grid,.reward-catalog-filters{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 860px){.app-shell{width:min(100%,calc(100% - 1.3rem));padding-top:1.15rem;padding-bottom:1.8rem}.admin-shell{grid-template-columns:1fr}.admin-sidebar{display:none}.admin-menu-toggle{display:inline-flex}.customer-header__top{gap:.62rem}.customer-header__logo{width:min(90px,27vw)}.customer-header__greeting{font-size:clamp(2rem,3.3vw,2rem)}.panel{padding:.9rem}.dashboard-header{padding:1.2rem}.tab-nav{gap:.42rem}.tab-button{padding-inline:.72rem}.redemption-scan-split{grid-template-columns:1fr;gap:.68rem}.reward-details-split,.member-details-split,.user-details-split{grid-template-columns:1fr}.logs-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.customer-home-grid{grid-template-columns:1fr}.customer-home-grid .panel--home-overview,.customer-home-grid .panel--home-catalog{grid-column:auto}.customer-pets-grid{grid-template-columns:1fr}.customer-pets-grid .panel--pets-list,.customer-pets-grid .panel--pets-form{grid-column:auto}.reward-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 720px){.app-shell{width:min(100%,calc(100% - 1rem));padding-top:1.1rem;padding-bottom:6.8rem}.app-shell.admin-shell{padding-bottom:1.3rem}.hero,.dashboard-header,.panel{border-radius:14px}.dashboard-header{flex-direction:column;align-items:flex-start}.dashboard-header--admin{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:.58rem}.customer-header{gap:.35rem}.customer-header__top{gap:.5rem}.customer-tabs--desktop,.customer-header__logout--desktop{display:none}.customer-header__mobile-actions{margin-left:auto;display:flex;align-items:center;gap:.36rem}.admin-menu-toggle{width:34px;height:34px;border-radius:9px}.customer-header__logout--mobile{display:inline-flex;width:auto;min-height:34px;border-radius:9px;font-size:.8rem;padding:.42rem .64rem}.customer-mobile-nav{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.36rem;position:fixed;left:0;right:0;bottom:0;z-index:45;border-top:1px solid var(--line);background:#fffffff5;box-shadow:0 -8px 24px #0f172a1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.45rem calc(.5rem + env(safe-area-inset-right)) calc(.45rem + env(safe-area-inset-bottom)) calc(.5rem + env(safe-area-inset-left))}.customer-mobile-nav__button{min-height:66px;padding:.48rem .32rem;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.32rem;text-align:center}.customer-mobile-nav__icon{width:28px;height:28px}.customer-mobile-nav__icon svg{width:17px;height:17px}.customer-mobile-nav__label{font-size:.66rem;line-height:1.12}.dashboard-header .secondary-button,.dashboard-header .primary-button{width:100%}.dashboard-header--admin .admin-header-logout{width:auto}.panel__header{flex-direction:column;align-items:flex-start}.panel__header--members{flex-direction:row;align-items:center}.stats-grid{grid-template-columns:1fr}.customer-home-points__bottom{gap:.6rem}.auth-grid,.layout-grid{grid-template-columns:1fr}.panel,.panel--wide,.panel--compact,.panel--half{grid-column:auto}.tab-nav{flex-wrap:nowrap;overflow-x:auto;padding-bottom:.4rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.tab-button{flex:0 0 auto;min-height:38px}.logs-filters{grid-template-columns:1fr;gap:.46rem}.data-table{min-width:560px}.mobile-record-list{margin-top:.75rem;display:grid;gap:.58rem}.mobile-hide-table{display:none}.camera-controls{flex-direction:column;align-items:stretch}.camera-controls .text-button,.camera-controls .secondary-button{width:100%;text-align:center}.camera-preview{max-height:300px;object-fit:cover}.auth-logo{width:min(165px,62vw)}.auth-admin-dot{width:16px;height:16px;right:max(14px,env(safe-area-inset-right));bottom:max(14px,env(safe-area-inset-bottom))}}@media (max-width: 520px){.app-shell{width:min(100%,calc(100% - .8rem));padding-bottom:7rem}.panel{padding:.78rem;border-radius:12px}.hero,.dashboard-header{border-radius:12px;padding:1rem}.panel__title{font-size:1rem}.pets-title{font-size:1.38rem}.pet-form-title{font-size:1.2rem}.customer-home-heading{gap:.45rem}.customer-home-day{font-size:1rem}.customer-home-name{font-size:clamp(1.5rem,6vw,2rem)}.secondary-button.customer-home-logout{min-height:32px;padding:.34rem .56rem;font-size:.76rem}.customer-header__logo{width:min(84px,30vw)}.customer-header__greeting{font-size:clamp(1.25rem,4.4vw,1.25rem)}.customer-header__logout--mobile{width:auto;min-height:32px;font-size:.75rem;padding:.36rem .58rem}.customer-mobile-nav{gap:.28rem;padding-left:calc(.4rem + env(safe-area-inset-left));padding-right:calc(.4rem + env(safe-area-inset-right))}.customer-mobile-nav__button{min-height:62px;padding:.42rem .22rem}.customer-mobile-nav__icon{width:25px;height:25px}.customer-mobile-nav__icon svg{width:15px;height:15px}.customer-mobile-nav__label{font-size:.62rem}.pet-icon-button{width:28px;height:28px}.pet-icon-button svg{width:15px;height:15px}.stat-card{min-height:112px;padding:.8rem}.stat-card__value{font-size:1.5rem}.customer-home-points__main{padding:1rem .85rem}.customer-home-points__reserved-badge{font-size:.68rem;padding:.18rem .46rem}.customer-home-points__mini{padding:.72rem}.customer-home-points__mini-value{font-size:1.36rem}.reward-grid,.reward-catalog-filters{grid-template-columns:1fr}.reward-card__footer .secondary-button,.reward-card__footer .primary-button{width:100%}.qr-image{width:min(176px,56vw);height:auto;aspect-ratio:1 / 1}.qr-modal-backdrop{padding:.72rem}.qr-modal{width:min(100%,360px);border-radius:12px;padding:.78rem}.admin-form-modal-backdrop{padding:.72rem}.admin-form-modal{width:min(100%,440px);border-radius:12px;padding:.78rem}.token-label{font-size:.74rem}.data-table{min-width:500px}.data-table th,.data-table td{padding:.5rem .35rem;font-size:.82rem}.table-wrap{margin-left:-.2rem;margin-right:-.2rem;padding-left:.2rem;padding-right:.2rem}.primary-button,.secondary-button{width:100%}.dashboard-header--admin .admin-header-logout{width:auto;min-height:32px;padding:.34rem .56rem;font-size:.76rem}.admin-mobile-drawer{width:min(88vw,300px);padding:.78rem}.customer-header__logout--mobile{width:auto}.camera-controls .text-button{border:1px solid var(--line);border-radius:10px;background:#fff;padding:.54rem .72rem;text-decoration:none}.auth-page{padding-top:.4rem;padding-bottom:1rem}.auth-single{margin-top:.55rem}}@media (max-width: 420px){.app-shell{width:min(100%,calc(100% - .55rem));padding:1rem 1.25rem 7.1rem}.panel,.hero,.dashboard-header{padding:.72rem}.customer-header__logo{width:min(76px,31vw)}.customer-home-day{font-size:1rem}.customer-home-name{font-size:clamp(1.5rem,9vw,1.75rem)}.secondary-button.customer-home-logout{min-height:30px;padding:.3rem .5rem;font-size:.72rem}.customer-mobile-nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:.22rem;padding-left:calc(.34rem + env(safe-area-inset-left));padding-right:calc(.34rem + env(safe-area-inset-right))}.customer-mobile-nav__button{min-height:59px;padding:.34rem .16rem;border-radius:10px}.customer-mobile-nav__icon{width:23px;height:23px}.customer-mobile-nav__label{font-size:.58rem}.pet-icon-button{width:26px;height:26px;border-radius:7px}.pet-icon-button svg{width:14px;height:14px}.hero__eyebrow{font-size:.7rem;letter-spacing:.06em}.dashboard-header h1{font-size:clamp(1.2rem,6.2vw,1.4rem)}.dashboard-header--admin .admin-header-logout{min-height:30px;padding:.3rem .5rem;font-size:.72rem}.customer-home-points__bottom{grid-template-columns:repeat(2,minmax(0,1fr));gap:.38rem}.customer-home-points__value{font-size:clamp(1.95rem,9vw,2.3rem)}.tab-button{min-height:36px;font-size:.8rem;padding-inline:.62rem}.data-table{min-width:460px}.data-table th,.data-table td{font-size:.78rem;padding:.45rem .3rem}.token-label{font-size:.7rem}.auth-logo{width:min(150px,64vw)}.auth-admin-dot{width:14px;height:14px}.admin-mobile-drawer{width:min(90vw,280px);padding:.72rem}.admin-mobile-drawer__head h3{font-size:1rem}.admin-form-modal{width:min(100%,360px);padding:.72rem}}
