.loyalty-summary{margin-top:1.5rem;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);grid-gap:1rem;gap:1rem}.loyalty-summary__hero{position:relative;overflow:hidden;padding:1.5rem;border-radius:32px;color:#fff;background:radial-gradient(circle at 88% 18%,rgba(255,209,102,.32),transparent 15rem),linear-gradient(135deg,#201610,#6c2a12 56%,#ff5a1f);box-shadow:0 28px 80px rgba(33,23,15,.2)}.loyalty-summary__hero:before{content:"";position:absolute;inset:auto -6% -48% auto;width:16rem;height:16rem;border-radius:999px;background:rgba(255,255,255,.1)}.loyalty-summary__hero>*{position:relative;z-index:1}.loyalty-summary__badge{display:inline-flex;align-items:center;gap:.45rem;min-height:34px;padding:.35rem .78rem;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.16);font-size:.78rem;font-weight:800}.loyalty-summary__value{margin:1rem 0 0;font-size:clamp(2.7rem,5vw,4rem);line-height:.95;letter-spacing:-.08em;font-weight:900}.loyalty-summary__label{max-width:32rem;margin:.65rem 0 0;color:rgba(255,255,255,.82);line-height:1.7}.loyalty-summary__stats{display:grid;grid-template-columns:1fr;grid-gap:.9rem;gap:.9rem}.loyalty-summary__stat{padding:1.2rem;border-radius:26px;border:1px solid rgba(234,223,206,.84);background:rgba(255,255,255,.88);box-shadow:0 14px 34px rgba(61,42,23,.06)}.loyalty-summary__stat strong{display:block;color:var(--text-primary);font-size:1.45rem;line-height:1;letter-spacing:-.05em;font-weight:900}.loyalty-summary__stat span{display:block;margin-top:.3rem;color:var(--text-secondary);font-size:.82rem;font-weight:700}@media (max-width:991.98px){.loyalty-summary{grid-template-columns:1fr}}@media (max-width:575.98px){.loyalty-summary__hero,.loyalty-summary__stat{border-radius:24px}.loyalty-summary__hero{padding:1.2rem}}.loyalty-history-card{padding:1rem 1.05rem;border-radius:28px;border:1px solid rgba(234,223,206,.84);background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,249,240,.94));box-shadow:0 8px 24px rgba(61,42,23,.06),0 18px 48px rgba(61,42,23,.08);display:flex;align-items:center;justify-content:space-between;gap:1rem}.loyalty-history-card.is-clickable{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.loyalty-history-card.is-clickable:hover{transform:translateY(-2px);border-color:rgba(239,105,48,.24);box-shadow:0 12px 28px rgba(61,42,23,.08),0 22px 54px rgba(239,105,48,.1)}.loyalty-history-card.is-clickable:focus-visible{outline:none;border-color:rgba(239,105,48,.42);box-shadow:0 0 0 4px rgba(239,105,48,.16),0 18px 48px rgba(61,42,23,.08)}.loyalty-history-card__main{min-width:0;display:flex;align-items:flex-start;gap:.85rem}.loyalty-history-card__icon{width:46px;height:46px;flex-shrink:0;border-radius:17px;display:inline-flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 12px 24px rgba(61,42,23,.14)}.loyalty-history-card__icon.is-positive{background:linear-gradient(135deg,#1f9d59,#38d27f)}.loyalty-history-card__icon.is-negative{background:linear-gradient(135deg,#ff8d5f,#d24a1b)}.loyalty-history-card__content{min-width:0}.loyalty-history-card__title{margin:0;color:var(--text-primary);font-size:1rem;line-height:1.25;letter-spacing:-.03em;font-weight:900}.loyalty-history-card__hint{margin:.3rem 0 0;color:var(--text-secondary);line-height:1.65}.loyalty-history-card__meta{margin-top:.55rem}.loyalty-history-card__date{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-muted);font-size:.8rem;font-weight:700}.loyalty-history-card__aside{flex-shrink:0;text-align:right}.loyalty-history-card__points{display:block;font-size:1.15rem;line-height:1;letter-spacing:-.04em;font-weight:900}.loyalty-history-card__points.is-positive{color:#1f9d59}.loyalty-history-card__points.is-negative{color:#d24a1b}.loyalty-history-card__type{min-height:34px;margin-top:.6rem;padding:.35rem .72rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:800}.loyalty-history-card__type.is-earn{color:#1f9d59;background:rgba(31,157,89,.1)}.loyalty-history-card__type.is-spend{color:#b66a06;background:rgba(243,177,48,.16)}.loyalty-history-card__type.is-adjust,.loyalty-history-card__type.is-expire,.loyalty-history-card__type.is-other{color:var(--text-secondary);background:rgba(233,226,214,.6)}@media (max-width:767.98px){.loyalty-history-card{flex-direction:column;align-items:flex-start}.loyalty-history-card__aside{width:100%;text-align:left}}@media (max-width:575.98px){.loyalty-history-card{border-radius:22px}}.loyalty-order-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;background:rgba(15,12,10,.52);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);overscroll-behavior:none}.loyalty-order-modal__dialog{width:min(100%,960px);max-height:calc(100vh - 2rem)}.loyalty-order-modal__content{display:flex;flex-direction:column;max-height:inherit;overflow:hidden;border-radius:32px;border:1px solid rgba(255,255,255,.16);background:rgba(255,252,246,.98);box-shadow:0 28px 90px rgba(33,23,15,.28)}.loyalty-order-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.3rem 1.3rem 0}.loyalty-order-modal__title{margin:0;font-size:1.45rem;font-weight:900;letter-spacing:-.05em}.loyalty-order-modal__subtitle{margin:.35rem 0 0;color:var(--text-secondary);line-height:1.6}.loyalty-order-modal__body{min-height:0;flex:1 1 auto;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;padding:1.2rem 1.3rem 1.3rem}.loyalty-order-modal__reward{margin-bottom:1rem;padding:1rem 1.1rem;border-radius:24px;border:1px solid rgba(62,191,117,.18);background:linear-gradient(135deg,rgba(232,255,242,.92),rgba(248,255,250,.98));display:flex;align-items:center;justify-content:space-between;gap:1rem}.loyalty-order-modal__reward-label{color:#2e7d4c;font-size:.9rem;font-weight:800}.loyalty-order-modal__reward strong{color:#1f9d59;font-size:1.4rem;line-height:1;letter-spacing:-.05em}.loyalty-order-modal__empty,.loyalty-order-modal__loading{padding:1.1rem;border-radius:24px;border:1px solid rgba(234,223,206,.84);background:rgba(255,255,255,.82);color:var(--text-secondary);display:flex;align-items:center;gap:.65rem;font-weight:700}.loyalty-order-modal__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.9rem;gap:.9rem}.loyalty-order-modal__card{display:flex;flex-direction:column;align-items:flex-start;gap:.45rem;padding:1rem 1.05rem;border-radius:24px;border:1px solid rgba(234,223,206,.84);background:rgba(255,255,255,.82)}.loyalty-order-modal__label{color:var(--text-muted);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.loyalty-order-modal__value{color:var(--text-primary);font-weight:800}.loyalty-order-modal__section{margin-top:1rem;padding:1rem 1.05rem;border-radius:24px;border:1px solid rgba(234,223,206,.84);background:rgba(255,255,255,.82)}.loyalty-order-modal__section-title{margin-bottom:.9rem;color:var(--text-primary);font-size:1rem;font-weight:900;letter-spacing:-.03em}.loyalty-order-modal__items{display:flex;flex-direction:column;gap:.85rem}.loyalty-order-modal__item{display:flex;align-items:center;justify-content:space-between;gap:.9rem;padding:.95rem 0;border-top:1px solid rgba(234,223,206,.72)}.loyalty-order-modal__item:first-child{padding-top:0;border-top:none}.loyalty-order-modal__item-main{min-width:0;display:flex;align-items:center;gap:.85rem}.loyalty-order-modal__item-thumb{width:58px;height:58px;flex-shrink:0;border-radius:16px;object-fit:cover;border:1px solid rgba(234,223,206,.82);background:rgba(255,249,240,.94)}.loyalty-order-modal__item-name{color:var(--text-primary);font-size:.95rem;font-weight:800;line-height:1.35}.loyalty-order-modal__item-meta{margin-top:.2rem;color:var(--text-secondary);font-size:.82rem;font-weight:700}.loyalty-order-modal__item-total{flex-shrink:0;color:var(--text-primary);font-size:.92rem;font-weight:900}.loyalty-order-modal__totals{display:flex;flex-direction:column;gap:.7rem}.loyalty-order-modal__total-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;color:var(--text-secondary);font-weight:700}.loyalty-order-modal__total-row strong{color:var(--text-primary)}.loyalty-order-modal__total-row.is-grand{margin-top:.15rem;padding-top:.8rem;border-top:1px solid rgba(234,223,206,.82);color:var(--text-primary);font-size:1rem;font-weight:900}.loyalty-order-modal__total-row.is-grand strong{color:var(--accent-color)}.loyalty-order-modal__address-name{color:var(--text-primary);font-weight:800}.loyalty-order-modal__address-copy{margin-top:.35rem;color:var(--text-secondary);line-height:1.7}@media (max-width:767.98px){.loyalty-order-modal__grid{grid-template-columns:1fr}.loyalty-order-modal__item{align-items:flex-start;flex-direction:column}.loyalty-order-modal__item-total{padding-left:4.45rem}}@media (max-width:575.98px){.loyalty-order-modal__content{border-radius:24px}.loyalty-order-modal__body,.loyalty-order-modal__header{padding-left:1rem;padding-right:1rem}.loyalty-order-modal__reward{align-items:flex-start;flex-direction:column}.loyalty-order-modal__item-main{align-items:flex-start}.loyalty-order-modal__item-total{padding-left:0}}.loyalty-skeleton{display:flex;flex-direction:column;gap:1.3rem}.loyalty-skeleton__top{display:flex;flex-direction:column;gap:.75rem}.loyalty-skeleton__summary{padding:1.35rem;border-radius:30px;border:1px solid rgba(234,223,206,.84);background:rgba(255,252,247,.84)}.loyalty-skeleton__stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.9rem;gap:.9rem;margin-top:1rem}.loyalty-skeleton__list{display:flex;flex-direction:column;gap:.85rem}.loyalty-skeleton__card{padding:1.2rem;border-radius:24px;border:1px solid rgba(234,223,206,.84);background:rgba(255,255,255,.88)}@media (max-width:767.98px){.loyalty-skeleton__stats{grid-template-columns:1fr}}.loyalty-page{position:relative;overflow-x:hidden;padding-bottom:1rem}.loyalty-page:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 8% 0,rgba(255,209,102,.14),transparent 20rem),radial-gradient(circle at 100% 4%,rgba(var(--primary-rgb),.1),transparent 18rem)}.loyalty-page>*{position:relative;z-index:1}.loyalty-page__topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}.loyalty-page__title{margin:0;font-size:clamp(1.9rem,3.8vw,2.9rem);line-height:.98;letter-spacing:-.06em;font-weight:900}.loyalty-page__subtitle{max-width:720px;margin:.85rem 0 0;color:var(--text-secondary);line-height:1.76}.loyalty-page__cta{min-height:52px;border-radius:999px;padding:.75rem 1.3rem;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.loyalty-page__history,.loyalty-page__info{margin-top:1.5rem}.loyalty-page__info{display:flex;align-items:flex-start;gap:1rem;padding:1.2rem 1.25rem;border-radius:28px;border:1px solid rgba(234,223,206,.84);background:rgba(255,252,247,.88);box-shadow:0 14px 34px rgba(61,42,23,.06)}.loyalty-page__info-icon{width:50px;height:50px;flex-shrink:0;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 12px 24px rgba(var(--primary-rgb),.2)}.loyalty-page__history-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1rem}.loyalty-page__section-title{margin:0;font-size:clamp(1.22rem,2vw,1.55rem);line-height:1.1;letter-spacing:-.04em;font-weight:900}.loyalty-page__section-copy{margin:.45rem 0 0;color:var(--text-secondary);line-height:1.7}.loyalty-page__history-chip{min-height:40px;padding:.5rem .85rem;border-radius:999px;display:inline-flex;align-items:center;gap:.45rem;color:var(--text-secondary);background:rgba(255,252,247,.88);border:1px solid rgba(234,223,206,.84);font-size:.83rem;font-weight:800;white-space:nowrap}.loyalty-page__list{display:flex;flex-direction:column;gap:.9rem}.loyalty-page__pagination{margin-top:1.25rem}.loyalty-page__empty .empty-state{padding:2.2rem 1.2rem;border-radius:28px;background:rgba(255,252,247,.84);border:1px solid rgba(234,223,206,.82)}@media (max-width:991.98px){.loyalty-page__history-head,.loyalty-page__topbar{flex-direction:column;align-items:flex-start}}@media (max-width:575.98px){.loyalty-page__cta{width:100%}.loyalty-page__info{padding:1rem;border-radius:22px}.loyalty-page__history-chip{width:100%;justify-content:center}}