.loyalty-page{background:#f2f2f7;padding-bottom:0}.loyalty-content{max-width:1200px;margin:0 auto;padding:32px var(--spacing-side,20px) 80px}.loyalty-grid{display:grid;grid-template-columns:1fr;grid-gap:12px;gap:12px}@media(min-width:768px){.loyalty-grid{grid-template-columns:repeat(3,1fr);gap:16px}}@media(min-width:1024px){.loyalty-grid{grid-template-columns:repeat(3,1fr)}}.loyalty-empty{grid-column:1/-1;padding:80px 20px;text-align:center;color:var(--text-secondary);font-size:16px}.loyalty-card-wrap{container-type:inline-size;aspect-ratio:1;border-radius:var(--radius-l,24px);background:var(--card-bg,#fff);box-shadow:var(--shadow-card,0 4px 16px rgba(0,0,0,.04));border:.5px solid var(--border-color,rgba(0,0,0,.07));overflow:hidden;cursor:pointer;transition:transform .2s ease}.loyalty-card-wrap:active{transform:scale(.97)}.loyalty-card-wrap{transition:box-shadow .2s ease,transform .2s ease}.loyalty-card-wrap:hover{box-shadow:0 8px 24px rgba(0,0,0,.1)}.loyalty-card-face.loyalty-card-front{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:16px 14px 12px;gap:10px;text-align:center}.loyalty-card-logo-wrap{width:70%;height:45%;flex-shrink:0;display:flex;align-items:center;justify-content:center}.loyalty-card-logo-wrap img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}.loyalty-card-name{margin-top:auto;padding-top:20px;flex-shrink:0;font-size:clamp(12px,4cqi,16px);font-weight:600;color:var(--text-primary);line-height:1.2}.loyalty-card-desc{margin-bottom:20px;flex-shrink:0;font-size:15px;font-weight:400;color:var(--text-secondary);line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical}.loyalty-card-modal{max-width:520px}.lcm-header{flex-direction:column;text-align:center;gap:10px;padding-bottom:20px}.lcm-header,.lcm-logo{display:flex;align-items:center}.lcm-logo{width:80px;height:80px;justify-content:center}.lcm-logo img{width:100%;height:100%;object-fit:contain}.lcm-name{font-size:20px;font-weight:600;color:var(--text-primary)}.lcm-desc{font-size:14px;color:var(--text-secondary);line-height:1.45}.lcm-divider{height:1px;background:var(--border-color,rgba(0,0,0,.08));margin-bottom:20px}.lcm-conditions-label{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:12px}.lcm-conditions{font-size:15px;line-height:1.55;color:var(--text-primary);margin-bottom:20px}.lcm-conditions p{margin-bottom:8px}.lcm-conditions p:last-child{margin-bottom:0}.lcm-conditions ol,.lcm-conditions ul{padding-left:20px;margin-bottom:8px}.lcm-conditions li{margin-bottom:4px}.lcm-conditions strong{font-weight:700}.lcm-site-btn{width:100%;margin-top:4px}@keyframes loyalty-grid-in{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.loyalty-grid--animate{animation:loyalty-grid-in .35s ease both}.loyalty-skeleton{aspect-ratio:1;border-radius:var(--radius-l,24px);background:linear-gradient(90deg,var(--bg-secondary,#f2f2f7) 25%,var(--bg-tertiary,#e5e5ea) 50%,var(--bg-secondary,#f2f2f7) 75%);background-size:200% 100%;animation:loyalty-shimmer 1.4s infinite}@keyframes loyalty-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loyalty-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:10000;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}@media(min-width:768px){.loyalty-modal-overlay{align-items:center}}.loyalty-modal-overlay.open{opacity:1;pointer-events:auto}.loyalty-modal{position:relative;width:100%;max-width:480px;background:var(--card-bg,#fff);border-radius:24px 24px 0 0;padding:28px 24px calc(24px + env(safe-area-inset-bottom));max-height:90dvh;overflow-y:auto;transform:translateY(40px);transition:transform .35s cubic-bezier(.34,1.56,.64,1);scrollbar-width:none;-webkit-overflow-scrolling:touch}.loyalty-modal::-webkit-scrollbar{display:none}@media(min-width:768px){.loyalty-modal{border-radius:24px;padding:36px 32px;transform:translateY(24px)}}.loyalty-modal-overlay.open .loyalty-modal{transform:translateY(0)}.modal-drag-handle{width:36px;height:4px;background:var(--bg-tertiary,#e5e5ea);border-radius:2px;margin:0 auto 20px}@media(min-width:768px){.modal-drag-handle{display:none}}.modal-close-btn{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:var(--bg-secondary,#f2f2f7);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);padding:0;transition:background .2s;transition:transform .2s ease}.modal-close-btn:active{transform:scale(.92)}.modal-close-btn svg{transition:transform .3s ease}.modal-close-btn:hover{background:var(--bg-tertiary,#e5e5ea)}.modal-close-btn:hover svg{transform:rotate(90deg)}.modal-title{font-size:22px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.modal-subtitle{font-size:15px;color:var(--text-secondary);line-height:1.45;margin-bottom:24px}.modal-step-hint{font-size:12px;color:var(--text-secondary);margin-bottom:20px}.modal-field{margin-bottom:14px}.modal-field label{display:block;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px}.modal-field input{width:100%;height:48px;padding:0 16px;background:var(--bg-secondary,#f2f2f7);border:1.5px solid transparent;border-radius:12px;font-size:16px;font-family:inherit;color:var(--text-primary);outline:none;transition:border-color .2s}.modal-field input::placeholder{color:var(--text-secondary);opacity:.55}.modal-field input:focus{border-color:var(--accent,#007aff)}.modal-consent{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;cursor:pointer}.modal-consent input[type=checkbox]{width:18px;height:18px;margin-top:1px;flex-shrink:0;accent-color:var(--accent,#007aff);cursor:pointer}.modal-consent span{font-size:13px;color:var(--text-secondary);line-height:1.45}.modal-consent span a{color:var(--accent,#007aff);text-decoration:underline}.modal-btn-row{display:flex;gap:10px;margin-top:24px}.modal-btn-row .k8-btn{flex:1 1}.modal-relative-block{background:var(--bg-secondary,#f2f2f7);border-radius:16px;padding:16px;margin-bottom:12px}.modal-relative-block .relative-label{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:10px}.modal-relative-block .modal-field{margin-bottom:8px}.modal-relative-block .modal-field:last-child{margin-bottom:0}.modal-relative-block .modal-field input{background:var(--card-bg,#fff)}.loyalty-calendar{margin-bottom:4px}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cal-month{font-size:16px;font-weight:600}.cal-month,.cal-nav-btn{color:var(--text-primary)}.cal-nav-btn{width:32px;height:32px;border-radius:50%;background:var(--bg-secondary,#f2f2f7);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;transition:background .2s;transition:transform .2s ease}.cal-nav-btn:active{transform:scale(.92)}.cal-nav-btn:hover{background:var(--bg-tertiary,#e5e5ea)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px;text-align:center}.cal-weekdays span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);padding:4px 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:3px;gap:3px}.cal-day{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;border:none;background:transparent;cursor:default;transition:all .2s}.cal-day.available{background:var(--bg-secondary,#f2f2f7);color:var(--text-primary);cursor:pointer}.cal-day.available:hover{background:var(--bg-tertiary,#e5e5ea)}.cal-day.selected{background:var(--accent,#007aff);color:#fff;font-weight:700}.cal-day.unavailable{color:var(--text-secondary);opacity:.28}.cal-selected-info{background:var(--bg-secondary,#f2f2f7);border-radius:12px;padding:12px 16px;margin-top:16px;display:flex;align-items:center;justify-content:space-between}.cal-selected-info .info-label{font-size:13px;color:var(--text-secondary)}.cal-selected-info .info-value{font-size:14px;font-weight:600;color:var(--text-primary)}.time-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;margin-top:14px}.time-btn{padding:10px 8px;border-radius:10px;border:1.5px solid var(--border-color,rgba(0,0,0,.1));background:var(--card-bg,#fff);font-size:14px;font-weight:500;font-family:inherit;color:var(--text-primary);cursor:pointer;text-align:center;transition:all .2s}.time-btn:hover{border-color:var(--accent,#007aff);color:var(--accent,#007aff)}.time-btn.selected{background:var(--accent,#007aff);border-color:var(--accent,#007aff);color:#fff}.slots-empty,.slots-loading{padding:16px 0;text-align:center;font-size:14px;color:var(--text-secondary)}.modal-success{text-align:center;padding:8px 0}.modal-success .success-check{width:64px;height:64px;border-radius:50%;background:var(--bg-secondary,#f2f2f7);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:30px}.modal-success h3{font-size:22px;font-weight:600;margin-bottom:8px}.modal-success p{font-size:15px;color:var(--text-secondary);line-height:1.45;margin-bottom:0}.modal-booking-summary{background:var(--bg-secondary,#f2f2f7);border-radius:16px;padding:16px;margin:20px 0 24px;text-align:left}.modal-booking-summary .summary-row{display:flex;justify-content:space-between;align-items:baseline;font-size:14px}.modal-booking-summary .summary-row:not(:last-child){margin-bottom:8px}.modal-booking-summary .summary-row .summary-key{color:var(--text-secondary)}.modal-booking-summary .summary-row .summary-val{font-weight:600}