/* ============================================================
 MCATiers - Shop Page Styles
 ============================================================ */
i {
 font-size: 20px;
}
.shop-hero {
 display: flex;
 align-items: center;
 justify-content: space-between;
 gap: 1rem;
 padding: 2.5rem 0 1.75rem;
 flex-wrap: wrap;
}
.page-title { font-size: 2rem; font-weight: 900; }
.page-subtitle { color: var(--text3); font-size: 0.9rem; margin-top: 0.25rem; }
.shop-hero-badges { display: flex; gap: 0.5rem; flex-wrap: wrap; }

/* ── Ranks Grid ── */
.ranks-grid {
 display: grid;
 grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
 gap: 1.25rem;
 padding-bottom: 2rem;
}

.rank-card {
 background: var(--bg3);
 border: 2px solid var(--border);
 border-radius: 18px;
 overflow: hidden;
 transition: transform 0.2s ease, box-shadow 0.2s ease;
 position: relative;
}
.rank-card:hover {
 transform: translateY(-4px);
 box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}

/* Popular badge */
.rank-card.popular::before {
 content: ' Most Popular';
 position: absolute;
 top: 0; left: 50%;
 transform: translateX(-50%);
 background: var(--accent);
 color: #050a05;
 font-size: 0.7rem;
 font-weight: 800;
 padding: 0.2rem 1rem;
 border-radius: 0 0 10px 10px;
 letter-spacing: 0.05em;
 text-transform: uppercase;
 z-index: 2;
}

.rank-card-header {
 padding: 2rem 1.5rem 1.25rem;
 text-align: center;
 position: relative;
}
.rank-name-display {
 font-size: 2rem;
 font-weight: 900;
 letter-spacing: 0.05em;
 margin-bottom: 0.375rem;
 line-height: 1;
}
.rank-price {
 font-size: 1.75rem;
 font-weight: 800;
 color: var(--text);
 margin-bottom: 0.25rem;
}
.rank-price span {
 font-size: 1rem;
 font-weight: 500;
 color: var(--text3);
}
.rank-duration {
 font-size: 0.75rem;
 color: var(--text3);
 font-family: 'JetBrains Mono', monospace;
}

.rank-card-body { padding: 0 1.5rem 1.5rem; }

/* Features list */
.rank-features {
 list-style: none;
 padding: 0;
 margin: 0 0 1.25rem;
 display: flex;
 flex-direction: column;
 gap: 0.5rem;
}
.rank-feature-item {
 display: flex;
 align-items: center;
 gap: 0.5rem;
 font-size: 0.875rem;
 color: var(--text2);
}
.rank-feature-item::before {
 content: '✓';
 color: var(--accent);
 font-weight: 700;
 flex-shrink: 0;
}

/* Buy buttons */
.rank-actions {
 display: flex;
 flex-direction: column;
 gap: 0.5rem;
}
.btn-pay {
 display: flex;
 align-items: center;
 justify-content: center;
 gap: 0.5rem;
 padding: 0.6rem 1rem;
 border-radius: 10px;
 border: none;
 cursor: pointer;
 font-family: inherit;
 font-size: 0.875rem;
 font-weight: 700;
 transition: all 0.2s;
 text-decoration: none;
 width: 100%;
}
.btn-stripe {
 background: #635BFF;
 color: #000000;
}
.btn-stripe:hover { background: #5147e8; box-shadow: 0 4px 14px rgba(99,91,255,0.4); transform: translateY(-1px); }

.btn-paypal {
 background: rgba(0, 65, 106, 1);
 color: #fff;
}
.btn-paypal:hover { background: #005c99; box-shadow: 0 4px 14px rgba(0,112,186,0.4); transform: translateY(-1px); }

.btn-ad {
 background: var(--bg2);
 color: var(--text2);
 border: 1px solid var(--border);
}
.btn-ad:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-glow2); }

.rank-divider {
 display: flex;
 align-items: center;
 gap: 0.5rem;
 margin: 0.375rem 0;
 color: var(--text3);
 font-size: 0.7rem;
 text-transform: uppercase;
 letter-spacing: 0.08em;
}
.rank-divider::before,
.rank-divider::after {
 content: '';
 flex: 1;
 height: 1px;
 background: var(--border);
}

/* ── Ad Modal ── */
.ad-placeholder {
 background: var(--bg2);
 border: 1px solid var(--border);
 border-radius: 12px;
 min-height: 200px;
 display: flex;
 align-items: center;
 justify-content: center;
 overflow: hidden;
}
.ad-loading { text-align: center; padding: 2rem; }
.ad-placeholder iframe {
 width: 100%;
 min-height: 200px;
 border: none;
 border-radius: 12px;
}

/* ── Pay Modal ── */
.pay-rank-preview {
 text-align: center;
 padding: 1rem 0 1.25rem;
 border-bottom: 1px solid var(--border);
 margin-bottom: 1.25rem;
}
.pay-rank-preview .rank-name-display { font-size: 1.5rem; margin-bottom: 0.25rem; }
.pay-rank-preview .rank-price { font-size: 1.25rem; }

.pay-method-tabs {
 display: flex;
 gap: 0.5rem;
 margin-bottom: 1.25rem;
}
.pay-tab {
 flex: 1;
 padding: 0.6rem 0.75rem;
 border-radius: 10px;
 border: 1px solid var(--border);
 background: var(--bg2);
 color: var(--text2);
 font-weight: 600;
 font-size: 0.875rem;
 cursor: pointer;
 transition: all 0.2s;
 font-family: inherit;
 text-align: center;
}
.pay-tab.active { border-color: var(--accent); color: var(--accent); background: var(--accent-glow2); }

.pay-form-group { margin-bottom: 0.875rem; }
.pay-form-label { display: block; font-size: 0.8rem; color: var(--text2); margin-bottom: 0.35rem; font-weight: 600; }

/* Shop Notice */
.shop-notice {
 display: flex;
 gap: 0.75rem;
 align-items: flex-start;
 padding: 1rem 1.25rem;
 background: var(--bg2);
 border: 1px solid var(--border);
 border-radius: 12px;
 font-size: 0.8rem;
 color: var(--text3);
 margin-bottom: 3rem;
}
.shop-notice a { color: var(--accent); }

@media (max-width: 700px) {
 .ranks-grid { grid-template-columns: 1fr; }
 .shop-hero { flex-direction: column; }
}

/* ── Shop v2.0 improvements ── */
.scroll-reveal{opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s;}
.scroll-reveal.visible{opacity:1;transform:translateY(0);}

.rank-card {
 backdrop-filter:blur(16px);
 background:var(--glass-bg) !important;
 border-width:2px !important;
}
.rank-card::after {
 content:'';
 position:absolute;
 top:-50%; left:-50%;
 width:200%; height:200%;
 background:conic-gradient(transparent 0deg, var(--accent-glow2) 60deg, transparent 120deg);
 animation:rankRotate 6s linear infinite;
 z-index:0; pointer-events:none; opacity:.5;
}
@keyframes rankRotate { to{transform:rotate(360deg)} }
.rank-card-header, .rank-card-body { position:relative; z-index:1; }

/* ── Ad modal styles ── */
.ad-loading { text-align:center; padding:2rem 1rem; }
.ad-placeholder { text-align:center; padding:2.5rem 1.5rem; background:var(--bg2); }
.ad-placeholder-icon { margin:0 auto 1rem; width:64px; height:64px; border-radius:16px; background:var(--accent-glow2); display:flex; align-items:center; justify-content:center; }
.rank-feature-item { display:flex; align-items:center; gap:.5rem; font-size:.85rem; color:var(--text2); padding:.2rem 0; }
.rank-feature-item svg { flex-shrink:0; }
.scroll-reveal{opacity:0;transform:translateY(20px);transition:opacity .55s,transform .55s;}
.scroll-reveal.visible{opacity:1;transform:translateY(0);}
.rank-popular-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#000;font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:.2rem .75rem;border-radius:9999px;white-space:nowrap;box-shadow:0 4px 12px var(--accent-glow);}
