/* ============================================================
   RIFTLINK — public profile page (.pg)
   Sorgente: prototipo public.css (scoped sotto .pg) + adattamenti
   per il rendering full-browser e il builder preview.
   Theme = CSS vars settate inline dal PHP/JS:
     --pg-bg, --acc, --acc-2, --acc-ink, --pg-text, --pg-muted, --pg-font
   ============================================================ */
.pg{
  position:relative; min-height:100%;
  padding:0 22px 40px;
  color: var(--pg-text, #eef3ff);
  font-family: var(--pg-font, "Rajdhani"), system-ui, sans-serif;
}
/* atmospheric backdrop */
.pg::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(360px 240px at 50% -4%, var(--acc-glow, rgba(45,227,210,.30)), transparent 70%),
    radial-gradient(300px 300px at 90% 110%, var(--acc-glow2, rgba(200,170,110,.18)), transparent 70%);
}
.pg::after{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:28px 28px;
  mask-image: radial-gradient(circle at 50% 30%, #000 0%, transparent 75%);
}
.pg > *{ position:relative; z-index:1; }

/* hero banner */
.pg-hero{ height:86px; margin:0 -22px 0; position:relative; overflow:hidden; }
.pg-hero .ribbon{
  position:absolute; inset:0;
  background: linear-gradient(120deg, var(--acc) 0%, var(--acc-2) 100%);
  opacity:.92;
  clip-path: polygon(0 0,100% 0,100% 64%,0 100%);
}
.pg-hero .ribbon::after{
  content:""; position:absolute; inset:0; opacity:.4; mix-blend-mode:overlay;
  background-image:
    repeating-linear-gradient(60deg, rgba(255,255,255,.18) 0 2px, transparent 2px 9px);
}

/* avatar */
.pg-ava-wrap{ display:flex; justify-content:center; margin-top:-46px; }
.pg-ava{
  width:96px; height:104px; position:relative; padding:3px;
  background: linear-gradient(150deg, var(--acc), var(--acc-2));
  clip-path: polygon(50% 0,100% 26%,100% 74%,50% 100%,0 74%,0 26%);
  box-shadow: 0 0 30px var(--acc-glow, rgba(45,227,210,.5));
}
.pg-ava .fill{
  width:100%; height:100%;
  background: linear-gradient(160deg, #1a2336, #0a1020);
  clip-path: polygon(50% 0,100% 26%,100% 74%,50% 100%,0 74%,0 26%);
  display:grid; place-items:center;
  font-family:"Chakra Petch"; font-weight:700; font-size:34px; color:var(--acc);
  text-shadow:0 0 18px var(--acc-glow,rgba(45,227,210,.6));
  background-size:cover; background-position:center;
}

.pg-name{
  text-align:center; margin:14px 0 2px;
  font-family:"Chakra Petch"; font-weight:700; font-size:22px; letter-spacing:.06em;
  color:var(--pg-text);
}
.pg-handle{
  text-align:center; font-size:14px; letter-spacing:.16em; text-transform:lowercase;
  color:var(--acc); margin-bottom:10px;
}
.pg-bio{
  text-align:center; font-size:14.5px; line-height:1.5; color:var(--pg-muted,#aeb9d4);
  max-width:250px; margin:0 auto 22px; letter-spacing:.01em; text-wrap:pretty;
}
.pg-rank{
  display:flex; align-items:center; justify-content:center; gap:8px; margin:-4px auto 22px;
  font-family:"Chakra Petch"; font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--pg-muted);
}
.pg-rank svg{ width:14px; height:14px; color:var(--acc); flex:none; }
.pg-rank .pip{ width:14px;height:14px; color:var(--acc); }

/* link buttons */
.pg-links{ display:flex; flex-direction:column; gap:13px; }

/* --- style A: solid bevel (default) --- */
.pg-link{
  position:relative; display:flex; align-items:center; gap:12px;
  padding:16px 16px; text-decoration:none; color:var(--acc-ink,#06121a);
  font-family:"Chakra Petch"; font-weight:600; font-size:15px; letter-spacing:.04em;
  background: linear-gradient(135deg, var(--acc), var(--acc-2));
  clip-path: polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  box-shadow: 0 8px 24px -10px var(--acc-glow,rgba(45,227,210,.6));
  transition: transform .14s, box-shadow .22s, filter .2s;
  overflow:hidden;
}
.pg-link .lk-ico{ width:22px;height:22px; flex:none; display:grid; place-items:center; opacity:.9; }
.pg-link .lk-ico svg{ width:20px;height:20px; }
.pg-link .lk-txt{ flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pg-link .lk-arrow{ width:18px;height:18px; opacity:.7; flex:none; }
.pg-link .lk-arrow svg{ width:18px;height:18px; }
.pg-link::after{
  content:""; position:absolute; top:0; left:-60%; width:40%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);
  transform:skewX(-18deg); transition:left .5s;
}
.pg-link:hover{ transform:translateY(-2px); filter:brightness(1.05);
  box-shadow:0 14px 34px -10px var(--acc-glow,rgba(45,227,210,.85)); }
.pg-link:hover::after{ left:130%; }
.pg-link.feat{ box-shadow:0 0 0 1px var(--acc), 0 0 26px -4px var(--acc-glow,rgba(45,227,210,.7)); }
.pg-link.feat .star{ color:var(--acc-ink); }

/* --- style B: outline / ghost --- */
.pg[data-style="outline"] .pg-link{
  background: rgba(255,255,255,.03);
  color:var(--pg-text);
  border:0;
  box-shadow: inset 0 0 0 1.5px var(--acc), 0 6px 18px -12px var(--acc-glow,rgba(45,227,210,.5));
}
.pg[data-style="outline"] .pg-link .lk-ico,
.pg[data-style="outline"] .pg-link .lk-arrow{ color:var(--acc); opacity:1; }
.pg[data-style="outline"] .pg-link:hover{
  background: linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: inset 0 0 0 1.5px var(--acc), 0 0 22px -6px var(--acc-glow,rgba(45,227,210,.7));
}

/* --- style C: split frame --- */
.pg[data-style="split"] .pg-link{
  background: linear-gradient(180deg, var(--pg-card,#121d33), var(--pg-card2,#0c1426));
  color:var(--pg-text); padding-left:54px;
  box-shadow: inset 0 0 0 1px var(--line-c, rgba(255,255,255,.07)), 0 8px 22px -12px rgba(0,0,0,.7);
}
.pg[data-style="split"] .pg-link .lk-ico{
  position:absolute; left:0; top:0; bottom:0; width:42px; opacity:1; color:var(--acc-ink);
  background:linear-gradient(160deg,var(--acc),var(--acc-2));
  clip-path: polygon(10px 0,100% 0,100% 100%,0 100%,0 10px);
}
.pg[data-style="split"] .pg-link .lk-arrow{ color:var(--acc); opacity:.8; }
.pg[data-style="split"] .pg-link:hover{ box-shadow: inset 0 0 0 1px var(--acc), 0 10px 26px -12px var(--acc-glow,rgba(45,227,210,.6)); }

/* socials */
.pg-social{ display:flex; justify-content:center; gap:16px; margin-top:26px; flex-wrap:wrap; }
.pg-social a{
  width:42px; height:42px; display:grid; place-items:center; color:var(--acc);
  border:1px solid color-mix(in srgb, var(--acc) 40%, transparent);
  clip-path: polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  transition: background .15s, transform .14s, box-shadow .2s;
}
.pg-social a svg{ width:20px;height:20px; }
.pg-social a:hover{ background:color-mix(in srgb, var(--acc) 16%, transparent); transform:translateY(-2px);
  box-shadow:0 0 18px -4px var(--acc-glow,rgba(45,227,210,.6)); }

/* tasto "Profilo giocatore" (sotto nome/handle/tagline) */
.pg-profile{ text-align:center; margin:2px 0 20px; }
.pg-profile-btn{
  display:inline-flex; align-items:center; gap:8px; padding:9px 17px; text-decoration:none;
  color:var(--acc); font-family:"Chakra Petch"; font-weight:600; font-size:12px;
  letter-spacing:.12em; text-transform:uppercase;
  border:1px solid color-mix(in srgb, var(--acc) 45%, transparent);
  clip-path: polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px);
  transition: background .15s, transform .14s, box-shadow .2s;
}
.pg-profile-btn:hover{
  background:color-mix(in srgb, var(--acc) 14%, transparent); transform:translateY(-1px);
  box-shadow:0 0 20px -5px var(--acc-glow, rgba(45,227,210,.6));
}
.pg-profile-btn svg{ width:16px; height:16px; }

/* roster team (extras_html) */
.pg-roster{ margin:0 0 22px; }
.pg-roster-head{ text-align:center; font-family:"Chakra Petch"; font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--pg-muted); margin-bottom:12px; }
.pg-roster-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px 10px; }
.pg-roster-m{ display:flex; flex-direction:column; align-items:center; gap:6px; width:66px; text-decoration:none; color:var(--pg-text); }
.pg-roster-av{ position:relative; width:48px; height:48px; display:grid; place-items:center;
  font-family:"Chakra Petch"; font-weight:700; font-size:18px; color:var(--acc-ink);
  background:linear-gradient(150deg,var(--acc),var(--acc-2));
  clip-path: polygon(50% 0,100% 26%,100% 74%,50% 100%,0 74%,0 26%);
  box-shadow:0 0 16px -4px var(--acc-glow,rgba(45,227,210,.5)); }
.pg-roster-cap{ position:absolute; bottom:-2px; right:-2px; width:18px; height:18px; display:grid; place-items:center;
  font-size:10px; font-style:normal; font-weight:700; color:#fff; background:#11121a;
  border:1px solid var(--acc); border-radius:50%; }
.pg-roster-n{ font-size:11.5px; line-height:1.2; text-align:center; color:var(--pg-muted); max-width:66px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pg-roster-m:hover .pg-roster-n{ color:var(--pg-text); }

/* badge team sul profilo giocatore (sobrio, integrato) */
.profilo-team .pt-badge{ display:flex; align-items:center; gap:13px; max-width:560px; padding:14px 18px;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.09); border-radius:14px; color:#e9eefb; text-decoration:none;
  transition:border-color .15s, background .15s, transform .12s; }
.profilo-team .pt-badge:hover{ border-color:#ff8a1e; background:rgba(255,255,255,.05); transform:translateY(-1px); }
.profilo-team .pt-badge-logo{ width:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:11px;
  background:#1a2740 center/cover no-repeat; color:#ff8a1e; font-family:"Chakra Petch"; font-weight:700; font-size:18px; }
.profilo-team .pt-badge-main{ flex:1; min-width:0; display:flex; flex-direction:column; gap:3px; }
.profilo-team .pt-badge-main b{ font-size:1rem; font-weight:700; }
.profilo-team .pt-badge-main small{ color:#9fb0cc; font-size:.82rem; }
.profilo-team .pt-badge-ar{ color:#ff8a1e; opacity:.7; font-size:1.1rem; }

.pg-foot{
  margin-top:30px; text-align:center; font-family:"Chakra Petch";
  font-size:10px; letter-spacing:.34em; text-transform:uppercase; color:var(--pg-muted); opacity:.6;
}
.pg-foot b{ color:var(--acc); }
.pg-foot a{ color:inherit; text-decoration:none; }
.pg-foot a:hover b{ text-decoration:underline; }

/* hidden-link placeholder in preview */
.pg-empty{
  text-align:center; color:var(--pg-muted); font-size:13px; letter-spacing:.05em;
  padding:30px 10px; opacity:.7;
}

/* ---- adattamenti per il rendering full-browser (pagina pubblica) ---- */
.pg-screen{ display:flex; justify-content:center; width:100%; }
.pg-screen .pg{
  width:100%; max-width:480px; margin:0 auto; min-height:560px; overflow:hidden;
}
/* ---- pagina pubblica immersiva (full-bleed, chrome del sito nascosto) ---- */
.pg-immersive{ align-items:flex-start; justify-content:center; width:100%; min-height:100vh; }
.pg-immersive .pg{ min-height:100vh; }
/* nasconde nav/footer del sito e azzera padding del contenitore tema → bg edge-to-edge */
body.rbz-riftlink-public #rbz-nav,
body.rbz-riftlink-public #rbz-footer,
body.rbz-riftlink-public .side-btn-wrap{ display:none !important; }
body.rbz-riftlink-public #rbz-content,
body.rbz-riftlink-public .rbz-main-content{ padding:0 !important; margin:0 !important; max-width:none !important; }
body.rbz-riftlink-public .entry-content,
body.rbz-riftlink-public .page-content{ margin:0 !important; }

/* ---- blocco "Link" nella scheda giocatore: card-CTA verso la pagina link ---- */
.profilo-riftlink .rl-cta{
  display:flex; align-items:center; gap:14px; max-width:560px; padding:15px 18px;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.09);
  border-radius:14px; color:#e9eefb; text-decoration:none;
  transition:border-color .15s, background .15s, transform .12s;
}
.profilo-riftlink .rl-cta:hover{ border-color:var(--rl-accent,#2de3d2); background:rgba(255,255,255,.05); transform:translateY(-1px); }
.profilo-riftlink .rl-cta-ico{
  width:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:12px;
  color:var(--rl-accent,#2de3d2); background:color-mix(in srgb, var(--rl-accent,#2de3d2) 14%, transparent);
}
.profilo-riftlink .rl-cta-ico svg{ width:22px; height:22px; }
.profilo-riftlink .rl-cta-main{ flex:1; min-width:0; display:flex; flex-direction:column; gap:3px; }
.profilo-riftlink .rl-cta-main b{ font-size:1rem; font-weight:700; letter-spacing:.01em; }
.profilo-riftlink .rl-cta-main small{ color:#9fb0cc; font-size:.82rem; }
.profilo-riftlink .rl-cta-ar{ width:20px; height:20px; flex:none; color:var(--rl-accent,#2de3d2); opacity:.7; }
.profilo-riftlink .rl-cta-ar svg{ width:20px; height:20px; }
