/* =========================================================================
   Playmania Arcade — shared UX layer
   favourites/playlist + flying hearts + share modal + page transition + prev/next
   Loaded on: static arcade (generator), /html5 (Blade), /game-news (Blade)
   ========================================================================= */
:root{--pm-orange:#F97316;--pm-orange-deep:#EA580C;}

/* ---- distributor badge (replaces "Playable now") ---- */
.pm-badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;letter-spacing:.01em;color:#8a6f53;background:#FFF1E0;border:1px solid #F1E2CE;padding:4px 11px;border-radius:999px;line-height:1;}
.pm-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--pm-orange);flex-shrink:0;}
/* badge on the minimal html5/gamenews game cards */
.pm-gbadge{display:inline-flex;align-items:center;gap:4px;margin:0 12px 12px;font-size:10px;font-weight:700;color:#9a7c5c;background:#FFF1E0;border:1px solid #F1E2CE;padding:3px 8px;border-radius:999px;line-height:1;align-self:flex-start;}
.pm-gbadge::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--pm-orange);flex-shrink:0;}

/* ---- shared heart glyph layers ---- */
.pm-h-out{fill:none;stroke:#1A1A1A;stroke-width:2;opacity:.78;}
.pm-h-fill{fill:var(--pm-orange);opacity:0;transform:scale(.4);transform-origin:center;transition:opacity .18s,transform .2s cubic-bezier(.2,1.5,.5,1);}

/* ---- card heart (JS-injected on game cards) ---- */
.gcard{position:relative;}
.gcard .thumb{position:relative;}
article.card .card-img{position:relative;}
.pm-heart{position:absolute;top:9px;right:9px;z-index:6;width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;background:rgba(255,255,255,.92);box-shadow:0 4px 12px rgba(20,10,0,.18);display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s,background .15s;-webkit-tap-highlight-color:transparent;}
.pm-heart:hover{transform:scale(1.12);background:#fff;}
.pm-heart svg{width:18px;height:18px;display:block;}
.pm-heart.on .pm-h-out{opacity:0;}
.pm-heart.on .pm-h-fill{opacity:1;transform:scale(1);}
.pm-heart.pm-pop{animation:pmPop .42s cubic-bezier(.2,1.4,.4,1);}
@keyframes pmPop{0%{transform:scale(1);}40%{transform:scale(1.32);}100%{transform:scale(1);}}

/* ---- detail-page favourite button ---- */
.pm-fav-btn{display:inline-flex;align-items:center;gap:9px;font-family:inherit;font-size:16px;font-weight:700;cursor:pointer;border-radius:999px;padding:14px 26px;border:1px solid rgba(255,255,255,.32);background:rgba(255,255,255,.1);color:#fff;transition:background .15s,transform .1s,border-color .15s;}
.pm-fav-btn:hover{background:rgba(255,255,255,.18);}
.pm-fav-btn:active{transform:translateY(1px);}
.pm-fav-btn svg{width:19px;height:19px;}
.pm-fav-btn .pm-h-out{stroke:#fff;opacity:1;}
.pm-fav-btn .pm-h-fill{fill:#fff;}
.pm-fav-btn.on{background:var(--pm-orange);border-color:var(--pm-orange);}
.pm-fav-btn.on .pm-h-out{opacity:0;}
/* light variant for light backgrounds (html5 show page) */
.pm-fav-btn.pm-light{background:#fff;border:1px solid #E7D9C6;color:#1A1A1A;font-size:14px;padding:11px 20px;}
.pm-fav-btn.pm-light .pm-h-out{stroke:#1A1A1A;}
.pm-fav-btn.pm-light .pm-h-fill{fill:var(--pm-orange);}
.pm-fav-btn.pm-light.on{background:var(--pm-orange);color:#fff;border-color:var(--pm-orange);}
.pm-fav-btn.pm-light.on .pm-h-fill{fill:#fff;}

/* ---- nav heart ---- */
.pm-navheart{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;border:1px solid #E7D9C6;background:#fff;cursor:pointer;padding:0;flex-shrink:0;transition:border-color .15s,transform .12s;}
.pm-navheart:hover{border-color:var(--pm-orange);transform:translateY(-1px);}
.pm-navheart svg{width:19px;height:19px;}
.pm-navheart.has .pm-h-out{opacity:0;}
.pm-navheart.has .pm-h-fill{opacity:1;transform:scale(1);}
.pm-navheart .pm-count{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--pm-orange);color:#fff;font-size:11px;font-weight:800;display:none;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(249,115,22,.5);}
.pm-navheart.has .pm-count{display:flex;}
.pm-navheart.pm-bump{animation:pmPop .45s cubic-bezier(.2,1.4,.4,1);}

/* ---- flying heart ---- */
.pm-fly{position:fixed;z-index:99999;pointer-events:none;will-change:transform,opacity;}
.pm-fly svg{width:100%;height:100%;fill:var(--pm-orange);filter:drop-shadow(0 4px 10px rgba(249,115,22,.5));}

/* ---- page-transition overlay ---- */
#pm-transition{position:fixed;inset:0;z-index:100000;background:#0b0b0f;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .42s ease;}
#pm-transition.on{opacity:1;visibility:visible;}
.pm-tlogo{font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;font-weight:800;font-size:30px;letter-spacing:-.02em;color:#fff;display:flex;align-items:center;gap:11px;transform:translateY(10px) scale(.95);opacity:0;transition:transform .5s cubic-bezier(.2,.9,.3,1),opacity .5s;}
#pm-transition.on .pm-tlogo{transform:translateY(0) scale(1);opacity:1;}
.pm-tlogo .pm-tdot{color:var(--pm-orange);}
.pm-tlogo .pm-temoji{font-size:34px;display:inline-block;animation:pmSpin 1.1s ease-in-out infinite;}
@keyframes pmSpin{0%,100%{transform:rotate(-9deg);}50%{transform:rotate(9deg);}}

/* ---- next / prev chevrons ---- */
.pm-nav-arrow{position:fixed;top:50%;transform:translateY(-50%);z-index:40;width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.93);box-shadow:0 8px 24px rgba(20,10,0,.18);border:1px solid #F1E8DC;display:flex;align-items:center;justify-content:center;text-decoration:none;color:#1A1A1A;transition:background .15s;}
.pm-nav-arrow:hover{background:#fff;}
.pm-nav-arrow svg{width:22px;height:22px;stroke:#1A1A1A;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.pm-nav-prev{left:18px;animation:pmNudgeL 1.3s ease-in-out infinite;}
.pm-nav-next{right:18px;animation:pmNudge 1.3s ease-in-out infinite;}
@keyframes pmNudge{0%,55%,100%{transform:translateY(-50%) translateX(0);}70%{transform:translateY(-50%) translateX(6px);}85%{transform:translateY(-50%) translateX(2px);}}
@keyframes pmNudgeL{0%,55%,100%{transform:translateY(-50%) translateX(0);}70%{transform:translateY(-50%) translateX(-6px);}85%{transform:translateY(-50%) translateX(-2px);}}
.pm-nav-arrow .pm-arrow-lbl{position:absolute;bottom:-21px;left:50%;transform:translateX(-50%);font-size:9.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#9CA3AF;white-space:nowrap;}
@media(prefers-reduced-motion:reduce){.pm-nav-next,.pm-nav-prev{animation:none;}.pm-tlogo .pm-temoji{animation:none;}}
@media(max-width:760px){.pm-nav-arrow{width:42px;height:42px;}.pm-nav-arrow svg{width:18px;height:18px;}.pm-nav-arrow .pm-arrow-lbl{display:none;}.pm-nav-prev{left:8px;}.pm-nav-next{right:8px;}}

/* ---- share-with-a-friend modal ---- */
#pm-modal{position:fixed;inset:0;z-index:100001;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(15,12,10,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
#pm-modal.on{display:flex;}
.pm-modal-card{background:#fff;border-radius:20px;max-width:460px;width:100%;padding:28px 28px 26px;box-shadow:0 30px 80px rgba(20,10,0,.4);position:relative;font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;max-height:92vh;overflow-y:auto;animation:pmModalIn .25s cubic-bezier(.2,1,.3,1);}
@keyframes pmModalIn{from{opacity:0;transform:translateY(14px) scale(.98);}to{opacity:1;transform:none;}}
.pm-modal-esc{position:absolute;top:15px;right:15px;font-size:11px;font-weight:700;color:#9CA3AF;background:#F3F4F6;border:1px solid #E5E7EB;border-radius:7px;padding:4px 9px;cursor:pointer;letter-spacing:.04em;font-family:inherit;}
.pm-modal-esc:hover{background:#E5E7EB;color:#4B5563;}
.pm-modal-card h2{font-size:21px;font-weight:800;color:#1A1A1A;margin:0 0 4px;letter-spacing:-.02em;}
.pm-modal-card .pm-sub{font-size:13.5px;color:#6B7280;margin:0 0 18px;line-height:1.5;}
.pm-playlist{background:#FFF6EC;border:1px solid #F1E2CE;border-radius:12px;padding:11px 13px;margin-bottom:18px;max-height:128px;overflow-y:auto;}
.pm-playlist .pm-pl-h{font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#F97316;margin-bottom:7px;}
.pm-playlist .pm-pl-item{font-size:12.5px;font-weight:600;color:#4B5563;padding:2px 0;display:flex;gap:6px;}
.pm-playlist .pm-pl-item::before{content:"\2665";color:#F97316;}
.pm-playlist .pm-pl-empty{font-size:12.5px;color:#9CA3AF;}
.pm-row{display:flex;gap:11px;}
.pm-field{margin-bottom:12px;flex:1;min-width:0;}
.pm-field label{display:block;font-size:11px;font-weight:700;color:#374151;margin-bottom:5px;letter-spacing:.02em;}
.pm-field input{width:100%;border:1px solid #E5E7EB;border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit;color:#1A1A1A;background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;}
.pm-field input:focus{border-color:#F97316;box-shadow:0 0 0 3px rgba(249,115,22,.13);}
.pm-hp{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;}
.pm-send{width:100%;margin-top:8px;background:#E11D48;color:#fff;border:none;border-radius:11px;padding:13px;font-size:15px;font-weight:800;font-family:inherit;cursor:pointer;transition:background .15s,transform .1s;}
.pm-send:hover{background:#BE123C;}.pm-send:active{transform:translateY(1px);}
.pm-send:disabled{opacity:.6;cursor:not-allowed;}
.pm-err{color:#E11D48;font-size:12.5px;font-weight:600;margin-top:10px;display:none;text-align:center;}
.pm-modal-ok{text-align:center;padding:22px 4px 8px;}
.pm-modal-ok .pm-ok-ic{font-size:46px;line-height:1;}
.pm-modal-ok h3{font-size:20px;margin:12px 0 6px;color:#1A1A1A;}
.pm-modal-ok p{font-size:13.5px;color:#6B7280;margin:0;line-height:1.5;}
@media(max-width:480px){.pm-row{flex-direction:column;gap:0;}}
