/* ===== Макет «купонник» (бренд kazinopromo) ===== */
.cp-hero {
  padding: 50px 0 32px; text-align: center;
  background: radial-gradient(900px 320px at 50% -15%, color-mix(in srgb, var(--accent) 16%, transparent), transparent);
  border-bottom: 1px solid var(--border);
}
.cp-hero h1 { margin-bottom: 10px; }
.cp-hero p { color: var(--muted); max-width: 640px; margin: 0 auto 20px; font-size: clamp(16px, 2vw, 18px); }
.cp-chips { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.cp-chips span { background: var(--card); border: 1px solid var(--border); padding: 9px 18px; border-radius: 999px; font-weight: 600; font-size: 14px; }
.cp-chips span.active { background: var(--accent); color: #fff; border-color: transparent; }

.cp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 24px; padding: 38px 20px 12px; }
.cp-coupon {
  display: grid; grid-template-columns: 124px 1fr; background: var(--card);
  border: 1px solid var(--border); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow);
  position: relative; transition: transform .15s, border-color .15s;
}
.cp-coupon:hover { transform: translateY(-3px); border-color: color-mix(in srgb, var(--accent) 45%, var(--border)); }

.cp-value {
  background: linear-gradient(160deg, var(--accent), color-mix(in srgb, var(--accent) 55%, #000));
  color: #fff; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; padding: 20px 10px; text-align: center; position: relative;
}
.cp-deal { font-weight: 800; font-size: 30px; line-height: 1; text-shadow: 0 1px 3px rgba(0, 0, 0, .3); }
.cp-deal small { display: block; font-size: 12px; font-weight: 600; opacity: .85; margin-top: 4px; }
.cp-value .cp-logo { width: 44px; height: 44px; border-radius: 10px; background: rgba(255, 255, 255, .2); display: grid; place-items: center; font-weight: 800; font-size: 15px; }
/* перфорация-«отрыв» между ценностью и телом купона */
.cp-value::after {
  content: ""; position: absolute; right: -10px; top: 0; bottom: 0; width: 20px;
  background: radial-gradient(circle at center, transparent 0 7px, var(--card) 7px) right center / 20px 22px repeat-y;
}

.cp-body { padding: 18px 20px; display: flex; flex-direction: column; gap: 11px; }
.cp-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.cp-head h3 { margin: 0; font-size: 19px; }
.cp-verified { color: var(--green); font-size: 12px; font-weight: 800; white-space: nowrap; }
.cp-desc { color: var(--muted); margin: 0; font-size: 15px; }

.cp-reveal {
  display: flex; align-items: center; gap: 10px; border: 1.5px dashed color-mix(in srgb, var(--accent) 70%, var(--border));
  border-radius: 10px; padding: 9px 10px 9px 14px; background: var(--card-2);
}
.cp-code-hidden { font-weight: 700; letter-spacing: 2px; color: var(--muted); }
.cp-code-shown { display: none; font-weight: 800; letter-spacing: 1px; color: var(--accent); font-size: 18px; }
.cp-reveal.revealed .cp-code-hidden { display: none; }
.cp-reveal.revealed .cp-code-shown { display: inline; }
.cp-reveal-btn { margin-left: auto; background: var(--accent); color: #fff; border: none; border-radius: 8px; padding: 8px 14px; font-weight: 700; cursor: pointer; font: inherit; white-space: nowrap; }
.cp-reveal.revealed .cp-reveal-btn { background: var(--green); }

.cp-foot { font-size: 13px; color: var(--muted); }
.cp-foot a { color: var(--accent); font-weight: 700; }

@media (max-width: 440px) {
  .cp-coupon { grid-template-columns: 92px 1fr; }
  .cp-deal { font-size: 22px; }
}
