/* ============================================================
   PRIMEPASS — Membership / Fan Cards  ·  realistic card visuals
   + tier comparison matrix. Loaded on fan_card.php.
   Inherits palette tokens from style.css.
   ============================================================ */

:root {
    --m-ease: cubic-bezier(0.22, 1, 0.36, 1);
    --m-hairline: rgba(246,231,184,0.14);
}

/* ---- Section intro ---- */
.mship-intro { max-width: 820px; margin: 0 auto 44px; text-align: center; }
.mship-intro h2 {
    font-size: clamp(2.2rem, 4.4vw, 3.4rem); line-height: 1.04; letter-spacing: -0.02em;
    background: linear-gradient(180deg, #fbf7ec, #cdc6b3 130%);
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.mship-intro p { color: var(--text-muted); font-size: clamp(1rem, 1.3vw, 1.15rem); }

/* ============================================================
   REALISTIC CARD VISUALS
   ============================================================ */
.mcard-rail {
    display: grid; gap: 26px;
    grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1080px) { .mcard-rail { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px)  { .mcard-rail { grid-template-columns: 1fr; } }

.mcard-cell { position: relative; display: flex; flex-direction: column; }

/* "Most popular" ribbon */
.mcard-cell.popular { z-index: 2; }
.mcard-ribbon {
    position: absolute; top: -13px; left: 50%; transform: translateX(-50%); z-index: 5;
    padding: 6px 18px; border-radius: 999px; font-size: 0.66rem; font-weight: 800;
    letter-spacing: 0.16em; text-transform: uppercase; white-space: nowrap;
    background: linear-gradient(135deg, #f1dca0, #d4b46a); color: #2a1d05;
    box-shadow: 0 10px 26px -8px rgba(212,180,106,0.7);
}

/* The card itself — credit-card proportions, glossy, 3D tilt on hover */
.mcard {
    position: relative; aspect-ratio: 1.586; border-radius: 18px; overflow: hidden;
    padding: 22px 24px; color: #fff; cursor: pointer;
    box-shadow: 0 30px 60px -24px rgba(0,0,0,0.8), inset 0 1px 0 rgba(255,255,255,0.18);
    transform: perspective(1100px) rotateX(0deg) rotateY(0deg) translateY(0);
    transition: transform 0.5s var(--m-ease), box-shadow 0.5s var(--m-ease);
    display: flex; flex-direction: column; justify-content: space-between;
    isolation: isolate;
}
.mcard-cell:hover .mcard {
    transform: perspective(1100px) rotateX(6deg) rotateY(-7deg) translateY(-8px) scale(1.02);
    box-shadow: 0 50px 90px -30px rgba(0,0,0,0.85), inset 0 1px 0 rgba(255,255,255,0.25);
}
/* moving holographic sheen */
.mcard::after {
    content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;
    background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,0.28) 46%, rgba(255,255,255,0.05) 52%, transparent 66%);
    background-size: 250% 250%; background-position: 120% 0;
    transition: background-position 0.8s var(--m-ease);
    mix-blend-mode: overlay;
}
.mcard-cell:hover .mcard::after { background-position: -40% 0; }
/* subtle guilloché texture */
.mcard::before {
    content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: 0.5;
    background-image: radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1.4px);
    background-size: 14px 14px;
    -webkit-mask-image: radial-gradient(120% 90% at 80% 20%, #000, transparent 75%);
    mask-image: radial-gradient(120% 90% at 80% 20%, #000, transparent 75%);
}
.mcard > * { position: relative; z-index: 2; }

/* Tier finishes */
.mcard.general    { background: linear-gradient(135deg, #2b3a32 0%, #16201b 55%, #0c100e 100%); }
.mcard.event      { background: linear-gradient(135deg, #8a5a2b 0%, #5c3a1c 55%, #2f1e0f 100%); }
.mcard.vip        { background: linear-gradient(135deg, #e9c879 0%, #c79a3e 48%, #7c5a1e 100%); color: #2a1d05; }
.mcard.meet_greet { background: linear-gradient(135deg, #e7a17a 0%, #c76b57 50%, #6e2f3a 100%); }
.mcard.premium    { background: linear-gradient(135deg, #e8ebf0 0%, #b9c0cb 45%, #767d8b 100%); color: #1b2026; }
.mcard.backstage  { background: linear-gradient(135deg, #2a2f3a 0%, #11131a 55%, #05060a 100%); }
.mcard.backstage::before {
    opacity: 0.8;
    background-image: conic-gradient(from 0deg, rgba(126,201,154,0.18), rgba(212,180,106,0.18), rgba(138,177,224,0.18), rgba(126,201,154,0.18));
    background-size: cover; background-position: center;
}

.mcard-top { display: flex; justify-content: space-between; align-items: flex-start; }
.mcard-brand { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 1.05rem; letter-spacing: 0.02em; }
.mcard-brand small { display: block; font-family: 'Inter', sans-serif; font-weight: 600; font-size: 0.52rem; letter-spacing: 0.34em; text-transform: uppercase; opacity: 0.7; margin-top: 1px; }
.mcard-class { font-size: 0.58rem; letter-spacing: 0.2em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; background: rgba(255,255,255,0.16); border: 1px solid rgba(255,255,255,0.25); font-weight: 700; }

.mcard-chip {
    width: 44px; height: 33px; border-radius: 6px; margin: 2px 0;
    background: linear-gradient(135deg, #e9d28c, #b9933f);
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.2);
    position: relative;
}
.mcard-chip::before, .mcard-chip::after {
    content: ''; position: absolute; inset: 6px; border: 1px solid rgba(0,0,0,0.25); border-radius: 3px;
}
.mcard-chip::after { inset: 0; border: 0; border-left: 1px solid rgba(0,0,0,0.2); border-right: 1px solid rgba(0,0,0,0.2); left: 50%; width: 0; }

.mcard-tier { font-family: 'Playfair Display', serif; font-size: 1.4rem; line-height: 1.1; margin: 0; }
.mcard-number { font-family: 'Inter', monospace; font-size: 0.92rem; letter-spacing: 0.12em; opacity: 0.92; }
.mcard-bottom { display: flex; justify-content: space-between; align-items: flex-end; gap: 10px; }
.mcard-holder { font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; opacity: 0.78; }
.mcard-holder b { display: block; font-size: 0.86rem; letter-spacing: 0.06em; opacity: 1; margin-top: 2px; font-weight: 700; }
.mcard-valid { text-align: right; font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.78; }
.mcard-valid b { display: block; font-size: 0.84rem; letter-spacing: 0.04em; opacity: 1; margin-top: 2px; }

/* Price + unlock + CTA below each card */
.mcard-info { padding: 20px 4px 0; display: flex; flex-direction: column; flex: 1; }
.mcard-price { display: flex; align-items: baseline; gap: 8px; }
.mcard-price .amt { font-family: 'Playfair Display', serif; font-size: 2rem; color: var(--cream); line-height: 1; }
.mcard-price .cur { font-size: 0.62rem; color: var(--text-muted); letter-spacing: 0.12em; }
.mcard-price .per { color: var(--text-muted); font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase; margin-left: auto; }
.mcard-fx { color: var(--text-muted); font-size: 0.72rem; margin: 4px 0 0; }
.mcard-unlock { margin: 14px 0 16px; }
.mcard-unlock .lab { font-size: 0.64rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-light); margin-bottom: 8px; }
.mcard-unlock ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 7px; }
.mcard-unlock li { display: flex; gap: 9px; font-size: 0.86rem; color: var(--text-soft); }
.mcard-unlock li b { color: var(--cream); }
.mcard-unlock li .plus { color: var(--gold); font-weight: 800; flex-shrink: 0; }
.mcard-cta { margin-top: auto; }
.mcard-cta .btn { width: 100%; justify-content: center; }

/* ============================================================
   COMPARISON MATRIX
   ============================================================ */
.compare-wrap {
    margin-top: 12px; border: 1px solid var(--m-hairline); border-radius: 22px; overflow: hidden;
    background: linear-gradient(165deg, rgba(30,40,34,0.5), rgba(12,16,14,0.7));
    -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
}
.compare-scroll { overflow-x: auto; }
.ctable { width: 100%; border-collapse: collapse; min-width: 860px; }
.ctable th, .ctable td { padding: 14px 16px; text-align: center; border-bottom: 1px solid rgba(246,231,184,0.06); }
.ctable thead th { position: sticky; top: 0; background: rgba(12,16,14,0.96); z-index: 3; vertical-align: top; }
.ctable .feat { text-align: left; color: var(--text-soft); font-size: 0.9rem; position: sticky; left: 0; background: rgba(14,18,16,0.96); z-index: 2; min-width: 230px; }
.ctable thead .feat { z-index: 4; }

.cth-name { font-family: 'Playfair Display', serif; font-size: 1.06rem; color: var(--cream); }
.cth-price { font-family: 'Playfair Display', serif; font-size: 1.5rem; color: var(--gold-light); margin: 6px 0 2px; }
.cth-per { font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }
.cth-cta { margin-top: 12px; }
.cth-cta .btn { padding: 9px 16px; font-size: 0.8rem; }
.ctable thead th.col-popular { background: linear-gradient(180deg, rgba(212,180,106,0.16), rgba(12,16,14,0.96)); }
.ctable td.col-popular { background: rgba(212,180,106,0.05); }
.col-popular-tag { display: inline-block; margin-bottom: 6px; font-size: 0.58rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #f1dca0; }

.crow-group td {
    text-align: left; background: rgba(86,165,122,0.07);
    font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-light);
    font-weight: 700; padding: 11px 16px;
}
.cyes { color: var(--success); font-size: 1.05rem; }
.cno  { color: rgba(246,231,184,0.18); }
.cval { color: var(--cream); font-weight: 700; font-size: 0.92rem; }
.ctable tbody tr:hover td { background: rgba(126,201,154,0.05); }
.ctable tbody tr:hover td.feat { background: rgba(18,24,20,0.98); }

.compare-note { color: var(--text-muted); font-size: 0.86rem; margin-top: 18px; }

/* ============================================================
   ORDER TRACKING TIMELINE  (my_cards.php)
   ============================================================ */
.otl-wrap { padding: 4px 30px 20px; }
.otl-title { font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-light); margin-bottom: 16px; }
.otl { display: flex; align-items: flex-start; }
.otl-step { flex: 1 1 0; position: relative; text-align: center; padding-top: 30px; min-width: 0; }
.otl-step .dot {
    position: absolute; top: 0; left: 50%; transform: translateX(-50%);
    width: 26px; height: 26px; border-radius: 50%; z-index: 2;
    display: grid; place-items: center; font-size: 0.78rem; line-height: 1;
    background: var(--bg-soft); border: 2px solid var(--m-hairline); color: var(--text-muted);
    transition: all 0.3s var(--m-ease);
}
/* connector line entering each step from the left */
.otl-step::before {
    content: ''; position: absolute; top: 12px; left: -50%; width: 100%; height: 2px;
    background: var(--m-hairline); z-index: 1;
}
.otl-step:first-child::before { display: none; }
.otl-step .otl-label { font-size: 0.74rem; color: var(--text-muted); line-height: 1.3; }
.otl-step .otl-date { display: block; font-size: 0.64rem; color: var(--text-muted); margin-top: 3px; letter-spacing: 0.04em; }

/* reached (done or current) */
.otl-step.done .dot { background: var(--success); border-color: var(--success); color: #06120c; }
.otl-step.done::before, .otl-step.current::before { background: linear-gradient(90deg, var(--gold-dark), var(--gold)); }
.otl-step.done .otl-label, .otl-step.current .otl-label { color: var(--cream); font-weight: 600; }
.otl-step.current .dot {
    background: radial-gradient(circle at 40% 30%, #1a241e, #0c100e);
    border-color: var(--gold-light); color: var(--gold-light);
    box-shadow: 0 0 0 5px rgba(126,201,154,0.15); animation: otl-pulse 1.8s infinite;
}
@keyframes otl-pulse { 0%,100% { box-shadow: 0 0 0 5px rgba(126,201,154,0.15); } 50% { box-shadow: 0 0 0 9px rgba(126,201,154,0.04); } }
.otl-step.returned .dot { background: var(--danger); border-color: var(--danger); color: #2a0d0d; }
.otl-step.returned .otl-label { color: #f3c4c4; }

@media (max-width: 560px) {
    .otl { flex-direction: column; align-items: stretch; gap: 0; }
    .otl-step { display: flex; gap: 14px; text-align: left; padding: 0 0 22px 0; }
    .otl-step .dot { position: static; transform: none; flex-shrink: 0; }
    .otl-step::before { left: 12px; top: 26px; width: 2px; height: 100%; }
    .otl-step:first-child::before { display: block; }
    .otl-step:last-child::before { display: none; }
}

/* belonging strip */
.belong {
    margin-top: 8px; display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
    padding: 18px 22px; border-radius: 16px; border: 1px solid var(--m-hairline);
    background: linear-gradient(120deg, rgba(86,165,122,0.1), rgba(212,180,106,0.05));
}
.belong .em { font-size: 1.5rem; }
.belong p { margin: 0; color: var(--text-soft); font-size: 0.92rem; }
.belong b { color: var(--cream); }
