
.crb-wrap{max-width:1120px;margin:32px auto;padding:24px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:20px;font-family:Inter,Arial,sans-serif;color:#0f172a}
.crb-header{margin-bottom:24px}
.crb-kicker{font-size:11px;letter-spacing:.12em;color:#475569;font-weight:700;margin-bottom:8px}
.crb-header h2{font-size:30px;line-height:1.15;margin:0 0 8px;color:#0f172a}
.crb-header p{margin:0;color:#475569;max-width:760px}
.crb-summary{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.crb-summary span{background:#fff;border:1px solid #e2e8f0;border-radius:999px;padding:9px 12px;font-size:13px}
.crb-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.crb-card,.crb-wild-card,.crb-claim-card{background:#fff;border:1px solid #dbe2ea;border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.04)}
.crb-card{padding:16px;display:flex;flex-direction:column;min-height:420px}
.crb-card.is-highlighted,.crb-card.is-unlocked,.crb-wild-card.is-highlighted{border-color:#1d4ed8;box-shadow:0 10px 28px rgba(29,78,216,.12)}
.crb-card-top,.crb-wild-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.crb-card-index{font-size:11px;font-weight:700;letter-spacing:.12em;color:#64748b;margin-bottom:5px}
.crb-tier-label{font-size:20px;font-weight:700;color:#0f172a}
.crb-status{font-size:11px;font-weight:700;padding:7px 10px;border-radius:999px;white-space:nowrap}
.status-claim-ready,.status-active{background:#dbeafe;color:#1d4ed8}
.status-completed{background:#ecfdf5;color:#047857}
.status-eligible{background:#fef3c7;color:#b45309}
.status-locked{background:#f1f5f9;color:#475569}
.crb-range{font-size:18px;font-weight:700;color:#0f172a;margin:12px 0 14px}
.crb-slider{position:relative}
.crb-slides{position:relative;overflow:hidden;min-height:170px}
.crb-slide{display:none;text-align:center}
.crb-slide.is-active{display:block}
.crb-image-wrap{height:120px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.crb-image-wrap img{width:100%;height:100%;object-fit:cover}
.crb-image-placeholder span{font-size:42px;color:#94a3b8}
.crb-gift-title{font-size:15px;font-weight:700;color:#0f172a;margin-top:10px}
.crb-badge{display:inline-block;margin-top:8px;padding:6px 10px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;font-size:12px;color:#1d4ed8}
.crb-dots{display:flex;justify-content:center;gap:6px;margin-top:10px}
.crb-dot{width:8px;height:8px;border:0;border-radius:999px;background:#cbd5e1;padding:0;cursor:pointer}
.crb-dot.is-active{background:#1d4ed8}
.crb-stats{display:flex;justify-content:space-between;gap:12px;font-size:13px;color:#475569;margin:14px 0 0}
.crb-card-bottom{margin-top:auto;padding-top:14px}
.crb-caption{font-size:13px;color:#475569;min-height:42px}
.crb-action-wrap{margin-top:12px}
.crb-claim-btn{width:100%;padding:11px 14px;border:0;border-radius:10px;background:#1d4ed8;color:#fff;font-weight:700;cursor:pointer}
.crb-claim-btn:hover{background:#1e40af}
.crb-claim-btn.is-loading{opacity:.65;pointer-events:none}
.crb-action-meta,.crb-no-action{font-size:12px;color:#64748b;margin-top:8px}
.crb-wild-card{margin-top:18px;padding:18px}
.crb-wild-head h3{margin:0 0 6px;font-size:24px}
.crb-wild-head p{margin:0;color:#475569;max-width:700px}
.crb-wild-progress{text-align:right}
.crb-wild-progress strong{display:block;font-size:28px}
.crb-wild-progress span{font-size:12px;color:#64748b}
.crb-wild-body{display:grid;grid-template-columns:1.35fr .9fr;gap:16px;align-items:start;margin-top:16px}
.crb-wild-meta{display:flex;flex-direction:column;justify-content:center;height:100%;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:16px}
.crb-claimed-wrap{margin-top:22px}
.crb-section-title{font-size:20px;font-weight:700;margin-bottom:14px}
.crb-claims-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.crb-claim-card{display:grid;grid-template-columns:120px 1fr;overflow:hidden}
.crb-claim-image img{width:100%;height:100%;object-fit:cover;display:block}
.crb-claim-body{padding:14px}
.crb-claim-tier{font-size:11px;font-weight:700;letter-spacing:.12em;color:#64748b;margin-bottom:5px}
.crb-claim-title{font-size:18px;font-weight:700}
.crb-claim-body p{margin:8px 0;color:#475569;font-size:14px}
.crb-claim-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:#64748b;margin-top:8px}
.crb-empty-claims,.crb-login-note{background:#fff;border:1px dashed #cbd5e1;padding:20px;border-radius:14px;color:#64748b}
.crb-modal[hidden]{display:none}
.crb-modal{position:fixed;inset:0;z-index:99999}
.crb-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55)}
.crb-modal-panel{position:relative;max-width:480px;margin:10vh auto 0;background:#fff;border-radius:18px;border:1px solid #dbe2ea;padding:22px;box-shadow:0 20px 60px rgba(15,23,42,.25)}
.crb-modal-close{position:absolute;top:10px;right:10px;width:34px;height:34px;border:0;background:#eff6ff;border-radius:999px;cursor:pointer;font-size:20px;color:#1d4ed8}
.crb-modal-kicker{font-size:11px;font-weight:700;letter-spacing:.12em;color:#64748b;margin-bottom:10px}
.crb-modal-card .crb-image-wrap{height:180px}
.crb-modal-card h4{margin:12px 0 4px;font-size:22px}
.crb-modal-card p{margin:8px 0 0;color:#475569}
@media (max-width: 980px){
  .crb-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .crb-wild-body,.crb-claims-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .crb-wrap{padding:16px;margin:16px auto}
  .crb-grid{grid-template-columns:1fr}
  .crb-card{min-height:auto}
  .crb-tier-label{font-size:18px}
  .crb-range{font-size:16px}
  .crb-claim-card{grid-template-columns:1fr}
}
