/* ════════════════════════════════════
   ARCAMIS — style-page.css
   Page hero, pbody, mappa interattiva,
   overlay admin, breadcrumb
════════════════════════════════════ */

/* ── Page hero ── */
#page-hero{
  min-height:260px;position:relative;overflow:hidden;
  background:#06080e;display:flex;align-items:flex-end;
  border-bottom:1px solid var(--ph-acc,rgba(200,155,60,.2));
}
.ph-covbg{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(.6) brightness(.45);transition:opacity .5s;}
.ph-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(4,6,12,.97) 0%,rgba(4,6,12,.65) 50%,rgba(4,6,12,.2) 100%);}
.ph-bg{position:absolute;inset:0;background:radial-gradient(ellipse 45% 110% at 12% 60%,rgba(200,155,60,.06),transparent),repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(200,155,60,.018) 80px),repeating-linear-gradient(0deg,transparent,transparent 49px,rgba(200,155,60,.014) 50px);}
.ph-btmline{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,155,60,.25),transparent);}
.ph-icon{position:absolute;right:44px;top:50%;transform:translateY(-50%);font-size:100px;opacity:.05;pointer-events:none;user-select:none}
.ph-inner{position:relative;padding:24px 44px 30px;z-index:2;width:100%}
.ph-crumb{display:flex;align-items:center;gap:5px;margin-bottom:14px;font-family:'Cinzel',serif;font-size:9px;letter-spacing:.12em;color:var(--text3)}
.ph-bc{cursor:pointer;transition:.15s}
.ph-bc:hover{color:var(--gold)}
.ph-sep{opacity:.3;padding:0 2px}
.ph-cur{color:rgba(200,155,60,.55);cursor:default}
.ph-eyebrow{font-family:'Cinzel',serif;font-size:9px;letter-spacing:.35em;color:var(--gold);opacity:.7;text-transform:uppercase;margin-bottom:8px}
.ph-title{font-family:'Cinzel',serif;font-size:34px;font-weight:700;color:var(--white);letter-spacing:.04em;text-shadow:0 2px 20px rgba(0,0,0,.95),0 0 60px rgba(200,155,60,.12);line-height:1.15}
.ph-sub{font-family:'Crimson Pro',serif;font-size:15px;color:rgba(196,168,98,.7);font-style:italic;margin-top:8px;letter-spacing:.02em}
.ph-divider{margin-top:18px;display:flex;align-items:center;gap:10px}
.ph-divider-line{flex:1;max-width:120px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);opacity:.5}
.ph-divider-gem{color:var(--gold);font-size:8px;opacity:.6}
.ph-topline{background:linear-gradient(90deg,transparent,var(--ph-acc,var(--gold3)),transparent)!important;opacity:.6!important}
.n-h1{color:var(--ph-acc,var(--white))!important}
#page-hero{border-bottom:1px solid var(--ph-acc,rgba(200,155,60,.2))}

/* Breadcrumb back link */
.ph-bc-mid{color:var(--parch);opacity:.55;cursor:pointer;font-family:'Cinzel',serif;font-size:10px;letter-spacing:.07em;transition:opacity .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px;}
.ph-bc-mid:hover{opacity:.9;color:var(--gold3)}

/* Page body */
#pbody{padding:36px 44px 60px;max-width:860px;margin:0 auto;width:100%}

/* ── Hero accent color ── */
.ph-topline{background:linear-gradient(90deg,transparent,var(--ph-acc,var(--gold3)),transparent)!important;opacity:.6!important}

/* ════════════════════════════════════
   MAPPA INTERATTIVA
════════════════════════════════════ */
.map-container{position:relative;overflow:hidden;margin-top:24px;line-height:0}
.map-tip{position:absolute;z-index:100;pointer-events:none;background:rgba(4,5,14,.96);border:1px solid rgba(200,155,60,.35);padding:10px 14px;min-width:155px;max-width:210px;opacity:0;transition:opacity .15s;box-shadow:0 8px 28px rgba(0,0,0,.75),0 0 18px rgba(200,155,60,.08);top:0;left:0;}
.map-tip.vis{opacity:1}
.map-tip-name{font-family:'Cinzel',serif;font-size:10.5px;font-weight:700;color:var(--gold3);letter-spacing:.1em;margin-bottom:3px}
.map-tip-desc{font-size:11.5px;color:var(--parch);font-style:italic;line-height:1.5;margin-bottom:4px}
.map-tip-hint{font-family:'Cinzel',serif;font-size:8px;color:var(--gold);letter-spacing:.1em;opacity:.65}
.map-tip-hint.sub{color:rgba(80,200,110,.75)}
.mpin{position:absolute;transform:translate(-50%,-50%);width:28px;height:28px;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;}
.mpin-dot{width:8px;height:8px;border-radius:50%;background:var(--pc,rgba(200,155,60,.9));box-shadow:0 0 8px var(--pg,rgba(200,155,60,.7));transition:transform .2s,box-shadow .2s;z-index:2;}
.mpin-ring{position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--pc,rgba(200,155,60,.5));animation:pinpulse 2.5s ease-out infinite;}
@keyframes pinpulse{0%{transform:scale(.6);opacity:.9}100%{transform:scale(2.2);opacity:0}}
.mpin:hover .mpin-dot{transform:scale(1.5);box-shadow:0 0 16px var(--pg,rgba(200,155,60,.9))}
.mpin.t-city{--pc:rgba(220,175,60,.95);--pg:rgba(220,175,60,.8)}
.mpin.t-village{--pc:rgba(200,155,60,.85);--pg:rgba(200,155,60,.65)}
.mpin.t-fort{--pc:rgba(190,130,50,.85);--pg:rgba(190,130,50,.65)}
.mpin.t-forest{--pc:rgba(60,200,80,.85);--pg:rgba(60,200,80,.65)}
.mpin.t-water{--pc:rgba(80,160,240,.85);--pg:rgba(80,160,240,.65)}
.mpin.t-ruin{--pc:rgba(150,80,240,.85);--pg:rgba(150,80,240,.7);animation-duration:3.5s}
.mpin.t-fog{--pc:rgba(140,100,240,.85);--pg:rgba(140,100,240,.7)}
.sub-map-panel{display:none;position:absolute;inset:0;z-index:40;background:rgba(4,5,14,.97);backdrop-filter:blur(6px);flex-direction:column;}
.sub-map-panel.open{display:flex}
.smp-header{padding:14px 20px;border-bottom:1px solid rgba(200,155,60,.18);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.smp-title{font-family:'Cinzel',serif;font-size:11px;font-weight:700;color:var(--gold3);letter-spacing:.2em;display:flex;align-items:center;gap:10px}
.smp-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--bdr);cursor:pointer;color:var(--text3);font-size:12px;transition:.15s;}
.smp-close:hover{color:#ff6060;border-color:#c03030}
.smp-body{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:16px}
.mloc{cursor:pointer}
.mloc .mc{transition:filter .2s}
.mloc:hover .mc{filter:drop-shadow(0 0 7px rgba(200,155,60,.8))}
.mloc .ml{font-family:'Cinzel',serif;fill:rgba(200,155,60,.6);font-weight:700;letter-spacing:.05em;pointer-events:none;transition:fill .2s}
.mloc:hover .ml{fill:rgba(220,175,60,.9)}

/* ════════════════════════════════════
   ARCADIA DECO LATERALI
════════════════════════════════════ */
.arc-deco{position:absolute;top:0;bottom:0;width:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;pointer-events:none;z-index:1;}
.arc-deco-l{left:12px;}
.arc-deco-r{right:12px;}
.arc-deco-line{flex:1;width:1px;background:linear-gradient(180deg,transparent,rgba(200,155,60,.3) 30%,rgba(200,155,60,.3) 70%,transparent);max-height:120px;}
.arc-deco-runes{font-size:10px;line-height:2;text-align:center;color:rgba(200,155,60,.22);letter-spacing:.05em;animation:runeflicker 4s ease-in-out infinite;}
.arc-deco-r .arc-deco-runes{animation-delay:1.8s;}
@media(max-width:768px){.arc-deco{display:none;}}

/* ════════════════════════════════════
   COPY LINK BUTTON
════════════════════════════════════ */
.ph-copy-btn{
  margin-top:14px;padding:5px 14px;
  background:rgba(200,155,60,.06);border:1px solid rgba(200,155,60,.2);
  color:rgba(200,155,60,.6);font-family:'Cinzel',serif;font-size:8px;
  letter-spacing:.15em;cursor:pointer;transition:.15s;
}
.ph-copy-btn:hover{background:rgba(200,155,60,.12);color:var(--gold2);border-color:rgba(200,155,60,.4)}

/* ════════════════════════════════════
   LOADING / ERROR
════════════════════════════════════ */
.ldwrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px;gap:14px;color:var(--text3)}
.spin{width:32px;height:32px;border:2px solid var(--bdr2);border-top-color:var(--gold);border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.errbox{background:rgba(90,15,8,.2);border:1px solid #5a1a10;padding:14px 18px;color:#c06050;font-size:14px;margin:20px 0}

/* ════════════════════════════════════
   RESPONSIVE PAGE
════════════════════════════════════ */
@media(max-width:768px){
  .ph-title{font-size:clamp(22px,6vw,40px)}
  .nc{padding:24px 16px 40px}
}
