.oly-p-root *{box-sizing:border-box;}
.oly-p-root{background:#141414;padding:24px 0 48px;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;}
.oly-p-empty{color:#888;padding:0 32px;}

.oly-p-grid{display:flex;flex-wrap:wrap;gap:16px;padding:6px 32px 10px;}

.oly-p-card{flex:0 0 280px;border-radius:4px;overflow:hidden;cursor:pointer;background:#1f1f1f;transition:transform .22s cubic-bezier(.25,.46,.45,.94);}
.oly-p-card:hover{transform:scale(1.06);z-index:10;}

.oly-p-thumb{width:100%;aspect-ratio:16/9;position:relative;overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center;}
.oly-p-thumb img{max-width:80%;max-height:80%;width:auto;height:auto;object-fit:contain;display:block;}
.oly-p-logo-placeholder{font-size:13px;font-weight:700;letter-spacing:.18em;color:rgba(255,255,255,.28);text-transform:uppercase;}

.oly-badge{position:absolute;top:8px;left:8px;font-size:10px;font-weight:800;padding:3px 7px;border-radius:2px;text-transform:uppercase;letter-spacing:.06em;z-index:3;}
.oly-badge-red{background:#e50914;color:#fff;}
.oly-badge-gold{background:#f5a623;color:#000;}
.oly-badge-green{background:#46d369;color:#000;}

.oly-p-info{padding:12px 14px 14px;background:#1f1f1f;}
.oly-p-name{font-size:14px;font-weight:800;color:#e5e5e5;margin-bottom:8px;text-transform:uppercase;letter-spacing:.02em;}
.oly-p-adv{margin:0 0 12px;}
.oly-p-adv-line{font-size:12px;color:rgba(255,255,255,.6);line-height:1.6;}
.oly-p-cta{display:inline-block;font-size:12px;font-weight:700;color:#46d369;letter-spacing:.03em;}

.oly-p-modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:99999;align-items:center;justify-content:center;padding:20px;}
.oly-p-modal-bg.open{display:flex;}
.oly-p-modal{background:#181818;border-radius:8px;width:100%;max-width:520px;padding:24px 26px 26px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.8);animation:olyPIn .2s ease;}
@keyframes olyPIn{from{opacity:0;transform:scale(.96) translateY(12px);}to{opacity:1;transform:scale(1) translateY(0);}}
.oly-p-modal-close{position:absolute;top:14px;right:14px;background:rgba(0,0,0,.6);border:none;color:#fff;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;}
.oly-p-modal-close:hover{background:rgba(255,255,255,.15);}
.oly-p-modal-type{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#46d369;margin-bottom:6px;}
.oly-p-modal-name{font-size:24px;font-weight:900;color:#fff;margin-bottom:16px;line-height:1.2;}
.oly-p-modal-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.oly-p-modal-tag{font-size:13px;color:rgba(255,255,255,.8);border:.5px solid rgba(255,255,255,.22);padding:6px 14px;border-radius:24px;}
.oly-p-modal-desc{font-size:14px;color:rgba(255,255,255,.72);line-height:1.65;margin-bottom:20px;}
.oly-p-modal-visit{display:inline-block;background:#46d369;color:#08210f;font-size:15px;font-weight:800;padding:12px 22px;border-radius:6px;text-decoration:none;transition:background .15s;}
.oly-p-modal-visit:hover{background:#5ee07e;color:#08210f;}
.oly-p-modal-visit.oly-p-hidden{display:none;}

@media(max-width:640px){
  .oly-p-grid{padding-left:16px;padding-right:16px;}
  .oly-p-card{flex:1 1 100%;}
}
