/* ═══════════════════════════════════════════════
   Morelos Rewards — Public CSS
   Fuentes: Playfair Display + Lora (Google Fonts)
   ═══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=Lora:ital,wght@0,400;0,500;1,400&display=swap');

:root {
    --mr-dark:    #1a2e2a;
    --mr-mid:     #2d5a4e;
    --mr-accent:  #ff7b5c;
    --mr-teal:    #00c4b4;
    --mr-sand:    #c4a882;
    --mr-bg:      #faf7f2;
    --mr-white:   #ffffff;
    --mr-border:  #ede8df;
    --mr-text:    #1a2e2a;
    --mr-muted:   #888;
    --mr-radius:  18px;
    --mr-shadow:  0 4px 24px rgba(0,0,0,.08);
}

.mr-dashboard { font-family: 'Lora', Georgia, serif; color: var(--mr-text); max-width: 680px; margin: 0 auto; }

/* ─── Hero ─────────────────────────────────────── */
.mr-hero {
    background: linear-gradient(155deg, var(--mr-dark) 0%, var(--mr-mid) 60%, #1a4a3a 100%);
    border-radius: var(--mr-radius);
    padding: 40px 32px 32px;
    position: relative;
    overflow: hidden;
    margin-bottom: 20px;
    text-align: center;
    color: #fff;
}
.mr-hero-bg {
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at 80% 20%, rgba(0,196,180,.15) 0%, transparent 60%);
    pointer-events: none;
}
.mr-hero-label   { color: #9dc9b8; font-size: 14px; letter-spacing: .5px; margin: 0 0 4px; }
.mr-hero-points  { font-family: 'Playfair Display', serif; font-size: 72px; line-height: 1; margin: 4px 0; }
.mr-hero-pts-label { color: #9dc9b8; font-size: 13px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 16px; }
.mr-tier-badge   { display: inline-block; padding: 4px 20px; border-radius: 20px; font-size: 13px; font-weight: 700; color: var(--mr-dark); margin-bottom: 16px; }
.mr-progress-wrap { margin-bottom: 20px; }
.mr-progress-bar { height: 8px; background: rgba(255,255,255,.15); border-radius: 10px; overflow: hidden; margin-bottom: 6px; }
.mr-progress-fill { height: 100%; border-radius: 10px; transition: width 1.2s cubic-bezier(.4,0,.2,1); }
.mr-progress-text { color: #9dc9b8; font-size: 13px; }
.mr-stats-row    { display: flex; justify-content: center; background: rgba(255,255,255,.08); border-radius: 14px; padding: 14px 20px; gap: 0; }
.mr-stat         { flex: 1; text-align: center; }
.mr-stat-n       { display: block; font-family: 'Playfair Display', serif; font-size: 24px; }
.mr-stat-l       { display: block; color: #9dc9b8; font-size: 11px; text-transform: uppercase; letter-spacing: .5px; margin-top: 2px; }
.mr-stat-div     { width: 1px; background: rgba(255,255,255,.15); margin: 4px 0; }

/* ─── Ref card ─────────────────────────────────── */
.mr-ref-card { background: var(--mr-white); border: 1px solid var(--mr-border); border-radius: var(--mr-radius); padding: 22px 24px; margin-bottom: 20px; box-shadow: var(--mr-shadow); }
.mr-ref-title { font-family: 'Playfair Display', serif; font-size: 17px; font-weight: 700; margin: 0 0 12px; }
.mr-ref-row { display: flex; gap: 10px; margin-bottom: 10px; align-items: center; }
.mr-ref-link { flex: 1; background: var(--mr-bg); border: 1.5px dashed var(--mr-sand); border-radius: 10px; padding: 9px 14px; font-family: monospace; font-size: 13px; color: var(--mr-mid); word-break: break-all; }
.mr-copy-btn { padding: 9px 18px; background: var(--mr-accent); color: #fff; border: none; border-radius: 10px; font-weight: 700; cursor: pointer; font-family: inherit; font-size: 13px; transition: background .2s, transform .1s; white-space: nowrap; }
.mr-copy-btn:hover { transform: translateY(-1px); }
.mr-copy-btn.copied { background: var(--mr-teal); }
.mr-earn-guide { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; font-size: 12px; color: #666; margin-bottom: 12px; }
.mr-earn-guide span:nth-child(even) { color: var(--mr-sand); }
.mr-share-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.mr-share-btn { padding: 8px 16px; border-radius: 20px; font-size: 12px; font-weight: 600; text-decoration: none; cursor: pointer; border: 1.5px solid; font-family: inherit; }
.mr-share-wa { background: #25D366; color: #fff; border-color: #25D366; }
.mr-share-ig { background: transparent; color: var(--mr-dark); border-color: var(--mr-border); }

/* ─── Tabs ─────────────────────────────────────── */
.mr-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.mr-tab { padding: 9px 18px; border: 1.5px solid var(--mr-border); background: var(--mr-white); border-radius: 20px; font-size: 13px; cursor: pointer; color: var(--mr-muted); font-family: inherit; transition: all .2s; }
.mr-tab.active, .mr-tab:hover { background: var(--mr-dark); color: #c4e8c2; border-color: var(--mr-dark); font-weight: 700; }
.mr-tab-content { display: none; }
.mr-tab-content.active { display: block; }

/* ─── Rewards grid ─────────────────────────────── */
.mr-rewards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; }
.mr-reward-card { background: var(--mr-white); border: 1px solid var(--mr-border); border-radius: var(--mr-radius); padding: 18px; transition: transform .2s, box-shadow .2s; }
.mr-reward-card:hover { transform: translateY(-4px); box-shadow: 0 8px 32px rgba(0,0,0,.12); }
.mr-reward-card.mr-locked { opacity: .65; }
.mr-reward-emoji { font-size: 36px; margin-bottom: 6px; }
.mr-reward-cat { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--mr-sand); }
.mr-reward-name { font-family: 'Playfair Display', serif; font-size: 15px; font-weight: 700; margin: 3px 0; }
.mr-reward-rest { font-size: 12px; color: var(--mr-muted); margin-bottom: 6px; }
.mr-reward-desc { font-size: 12px; color: #888; font-style: italic; margin-bottom: 8px; }
.mr-reward-footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.mr-reward-pts { font-weight: 700; font-size: 14px; color: var(--mr-mid); }
.mr-reward-tier { font-size: 10px; color: var(--mr-sand); border: 1px solid var(--mr-border); border-radius: 8px; padding: 2px 6px; }
.mr-redeem-btn { padding: 6px 14px; background: var(--mr-accent); color: #fff; border: none; border-radius: 20px; font-size: 12px; font-weight: 700; cursor: pointer; font-family: inherit; transition: transform .1s; }
.mr-redeem-btn:hover:not(:disabled) { transform: scale(1.05); }
.mr-redeem-disabled { background: #ccc !important; cursor: not-allowed !important; }

/* ─── Referidos ────────────────────────────────── */
.mr-referrals-list { display: flex; flex-direction: column; gap: 10px; }
.mr-ref-row-item { display: flex; align-items: center; gap: 14px; background: var(--mr-white); border: 1px solid var(--mr-border); border-radius: 14px; padding: 14px 18px; }
.mr-ref-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--mr-accent); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 18px; flex-shrink: 0; }
.mr-ref-info { flex: 1; }
.mr-ref-info strong { display: block; font-size: 14px; }
.mr-ref-date { font-size: 12px; color: var(--mr-muted); }
.mr-ref-right { text-align: right; }
.mr-ref-visits { display: block; font-size: 12px; color: var(--mr-muted); margin-top: 4px; }
.mr-badge-active  { background: #e8f8f0; color: #1a7a44; padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; }
.mr-badge-pending { background: #fff3e0; color: #b06000; padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; }

/* ─── Historial ─────────────────────────────────── */
.mr-history-list { display: flex; flex-direction: column; gap: 8px; }
.mr-history-item { display: flex; align-items: center; gap: 14px; background: var(--mr-white); border: 1px solid var(--mr-border); border-radius: 14px; padding: 12px 16px; }
.mr-history-icon { font-size: 22px; width: 36px; text-align: center; }
.mr-history-info { flex: 1; }
.mr-history-reason { font-size: 13px; margin: 0 0 2px; line-height: 1.3; }
.mr-history-date { font-size: 11px; color: var(--mr-muted); }
.mr-history-pts { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700; }
.mr-pts-earn   { color: var(--mr-teal); }
.mr-pts-redeem { color: var(--mr-accent); }

/* ─── Tiers ─────────────────────────────────────── */
.mr-tier-card { background: var(--mr-white); border: 2px solid var(--mr-border); border-radius: var(--mr-radius); padding: 20px 22px; margin-bottom: 12px; transition: border-color .3s; }
.mr-tier-current { border-color: var(--tc, var(--mr-teal)); box-shadow: 0 0 0 4px color-mix(in srgb, var(--tc, #00c4b4) 15%, transparent); }
.mr-tier-header { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 12px; }
.mr-tier-emoji { font-size: 32px; line-height: 1; }
.mr-tier-name { font-family: 'Playfair Display', serif; font-size: 20px; display: block; }
.mr-tier-you { font-size: 11px; background: var(--mr-dark); color: #c4e8c2; padding: 2px 10px; border-radius: 20px; }
.mr-tier-range { font-size: 12px; color: var(--mr-muted); margin: 4px 0 0; }
.mr-tier-perks { list-style: none; padding: 0; margin: 0; }
.mr-tier-perks li { font-size: 13px; padding: 4px 0; padding-left: 18px; position: relative; }
.mr-tier-perks li::before { content: '✓'; position: absolute; left: 0; color: var(--tc, var(--mr-teal)); font-weight: 700; }

/* ─── Modales ───────────────────────────────────── */
.mr-modal { position: fixed; inset: 0; background: rgba(0,0,0,.6); display: flex; align-items: center; justify-content: center; z-index: 9999; padding: 20px; backdrop-filter: blur(4px); }
.mr-modal-box { background: var(--mr-white); border-radius: 24px; padding: 36px; text-align: center; max-width: 360px; width: 100%; box-shadow: 0 20px 60px rgba(0,0,0,.25); }
.mr-modal-emoji { font-size: 56px; margin-bottom: 8px; }
.mr-modal-box h2 { font-family: 'Playfair Display', serif; font-size: 24px; margin: 0 0 8px; color: var(--mr-dark); }
.mr-modal-box p  { color: #666; font-size: 14px; margin-bottom: 12px; }
.mr-modal-actions { display: flex; gap: 10px; justify-content: center; margin-top: 20px; }
.mr-btn-confirm { padding: 12px 28px; background: var(--mr-dark); color: #c4e8c2; border: none; border-radius: 20px; font-size: 15px; font-weight: 700; cursor: pointer; font-family: inherit; }
.mr-btn-cancel  { padding: 12px 24px; background: var(--mr-bg); color: var(--mr-dark); border: 1.5px solid var(--mr-border); border-radius: 20px; font-size: 14px; cursor: pointer; font-family: inherit; }
.mr-code-display { background: var(--mr-dark); border-radius: 16px; padding: 20px; font-family: monospace; font-size: 26px; color: #c4e8c2; letter-spacing: 3px; font-weight: 700; margin: 16px 0; }
.mr-code-note { font-size: 12px; color: var(--mr-muted); margin-top: -4px; }

/* ─── Empty / login wall ────────────────────────── */
.mr-empty { text-align: center; padding: 40px; color: var(--mr-muted); font-size: 15px; line-height: 1.8; background: var(--mr-white); border: 1px solid var(--mr-border); border-radius: var(--mr-radius); }
.mr-login-wall { text-align: center; padding: 30px; background: var(--mr-bg); border-radius: var(--mr-radius); border: 1.5px dashed var(--mr-sand); }
.mr-login-wall a { color: var(--mr-accent); font-weight: 700; }

/* ─── Inline points ─────────────────────────────── */
.mr-inline-points { font-family: 'Playfair Display', serif; font-weight: 700; }
