/* =========================================================
   gg_page_shell.css — SHARED PAGE SHELL
   Purpose:
   - shared visual system for character/base/family/dynasty/inheritance/realestate
   - reduce giant inline page CSS duplication
   - safe utility shell only
   - does NOT own game state
   ========================================================= */

:root{
  --bg:#070814;
  --panel:rgba(10,14,28,.84);
  --panel2:rgba(255,255,255,.045);
  --line:rgba(255,255,255,.11);
  --txt:#eef2ff;
  --mut:rgba(238,242,255,.72);
  --blue:#73a8ff;
  --red:#ff6f91;
  --void:#7df1df;
  --gold:#f6d06f;
  --good:#6ee7a8;
  --bad:#ff7b93;
  --shadow:0 24px 64px rgba(0,0,0,.42);
  --radius:22px;
}

*{ box-sizing:border-box; }

html,body{
  margin:0;
  min-height:100%;
  background:
    radial-gradient(1200px 700px at 15% -10%, rgba(115,168,255,.16), transparent 60%),
    radial-gradient(900px 600px at 85% 0%, rgba(255,111,145,.14), transparent 55%),
    linear-gradient(180deg,#070814 0%,#0a1020 100%);
  color:var(--txt);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  display:block;
  max-width:100%;
}

.wrap{
  max-width:1480px;
  margin:0 auto;
  padding:22px 16px 80px;
}

.hero{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:30px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
    linear-gradient(180deg, rgba(115,168,255,.10), rgba(255,111,145,.06));
  box-shadow:var(--shadow);
  padding:24px;
  margin-bottom:18px;
}

.hero::before{
  content:"";
  position:absolute;
  inset:-20% auto auto -10%;
  width:320px;
  height:320px;
  background:radial-gradient(circle, rgba(115,168,255,.18), transparent 65%);
  pointer-events:none;
}

.hero::after{
  content:"";
  position:absolute;
  right:-60px;
  top:-40px;
  width:280px;
  height:280px;
  background:radial-gradient(circle, rgba(255,111,145,.14), transparent 65%);
  pointer-events:none;
}

.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:stretch;
}

.hero-grid.hero-grid-character{
  grid-template-columns:320px minmax(0,1fr);
}

.kicker{
  color:var(--mut);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:900;
}

.hero-title{
  margin:6px 0 0;
  font-size:40px;
  line-height:1;
  letter-spacing:-.04em;
  font-weight:1000;
}

.hero-name{
  margin:4px 0 0;
  font-size:34px;
  line-height:1;
  letter-spacing:-.04em;
  font-weight:1000;
}

.hero-copy,
.hero-sub{
  margin-top:10px;
  color:var(--mut);
  font-size:14px;
  line-height:1.6;
  max-width:860px;
}

.hero-side{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

.hero-side.hero-side-stack{
  grid-template-rows:auto auto auto 1fr;
  grid-template-columns:1fr;
  gap:16px;
}

.headline-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
}

.pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:9px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:#fff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.mini{
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background:rgba(255,255,255,.045);
  padding:14px;
}

.mini .k{
  color:var(--mut);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-weight:900;
}

.mini .v{
  margin-top:8px;
  font-size:28px;
  font-weight:1000;
  line-height:1;
  letter-spacing:-.03em;
}

.power-box{
  min-width:210px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background:rgba(255,255,255,.045);
  padding:14px 16px;
}

.power-k{
  color:var(--mut);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.power-v{
  margin-top:8px;
  font-size:38px;
  line-height:1;
  letter-spacing:-.04em;
  font-weight:1000;
}

.power-bar{
  margin-top:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
}

.power-fill{
  height:100%;
  width:0%;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(115,168,255,.92), rgba(255,111,145,.92));
  transition:width .25s ease;
}

.portrait{
  border:1px solid rgba(255,255,255,.12);
  border-radius:26px;
  padding:14px;
  background:rgba(255,255,255,.045);
  min-height:100%;
}

.portrait-frame{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(circle at 30% 20%, rgba(115,168,255,.22), transparent 40%),
    radial-gradient(circle at 80% 20%, rgba(255,111,145,.18), transparent 42%),
    linear-gradient(180deg,#11182c,#0b1020);
  aspect-ratio:4 / 5;
  display:flex;
  align-items:end;
  justify-content:center;
}

.portrait-img{
  width:100%;
  height:100%;
  object-fit:cover;
  position:relative;
  z-index:1;
}

.portrait-meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-top:12px;
}

.gg-avatar-wrap{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 30% 20%, rgba(115,168,255,.18), transparent 42%),
    radial-gradient(circle at 80% 18%, rgba(255,111,145,.16), transparent 40%),
    linear-gradient(180deg,#11182c,#0b1020);
}

.gg-avatar-fallback{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  z-index:0;
  pointer-events:none;
}

.gg-avatar-fallback-shape{
  width:54%;
  height:54%;
  border-radius:18px;
  background:
    linear-gradient(180deg, rgba(115,168,255,.28), rgba(255,111,145,.18)),
    rgba(255,255,255,.04);
  box-shadow:
    0 18px 40px rgba(0,0,0,.28),
    inset 0 0 0 1px rgba(255,255,255,.08);
  transform:rotate(8deg);
  opacity:.92;
}

.grid{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:16px;
  margin-top:16px;
}

.card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--panel);
  box-shadow:var(--shadow);
  padding:18px;
  min-width:0;
}

.span-3{ grid-column:span 3; }
.span-4{ grid-column:span 4; }
.span-5{ grid-column:span 5; }
.span-6{ grid-column:span 6; }
.span-7{ grid-column:span 7; }
.span-8{ grid-column:span 8; }
.span-12{ grid-column:span 12; }

.card-title{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}

.card-title h3{
  margin:0;
  font-size:17px;
  letter-spacing:-.02em;
}

.sub{
  color:var(--mut);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.10em;
}

.stats{
  display:grid;
  gap:10px;
}

.stat{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background:rgba(255,255,255,.035);
}

.stat .k{
  color:var(--mut);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.stat .v{
  color:#fff;
  font-size:20px;
  font-weight:1000;
  letter-spacing:-.02em;
  text-align:right;
}

.core-grid,
.mini-grid,
.builder-grid,
.legacy-grid,
.lot-grid,
.transfer-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

.core-cell,
.build-card,
.legacy-card,
.lot-card,
.transfer-card{
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  background:rgba(255,255,255,.035);
  padding:14px;
}

.core-cell .k{
  color:var(--mut);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:900;
}

.core-cell .v{
  margin-top:8px;
  font-size:28px;
  line-height:1;
  font-weight:1000;
  letter-spacing:-.03em;
}

.build-head,
.lot-head{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:flex-start;
}

.build-name,
.legacy-name,
.transfer-name{
  font-size:15px;
  font-weight:1000;
  line-height:1.1;
}

.build-cost,
.lot-price{
  font-size:12px;
  color:var(--gold);
  font-weight:900;
  white-space:nowrap;
}

.build-meta,
.legacy-copy,
.transfer-copy,
.lot-copy{
  margin-top:8px;
  color:var(--mut);
  font-size:12px;
  line-height:1.55;
}

.build-actions,
.actions,
.lot-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}

.btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:#fff;
  border-radius:14px;
  padding:12px 14px;
  font-size:13px;
  font-weight:900;
  letter-spacing:.04em;
  cursor:pointer;
}

.btn:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.08);
}

.btn[disabled]{
  cursor:not-allowed;
  opacity:.55;
  transform:none;
}

.items,
.line-list,
.family-list,
.people-grid{
  display:grid;
  gap:10px;
}

.item,
.line-member,
.member,
.family-member,
.person{
  display:grid;
  align-items:center;
  gap:12px;
  padding:12px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
}

.item{
  grid-template-columns:minmax(0,1fr) auto;
}

.line-member,
.member,
.person{
  grid-template-columns:72px minmax(0,1fr) auto;
}

.family-member{
  grid-template-columns:64px minmax(0,1fr) auto;
}

.item-left{
  min-width:0;
}

.item-name,
.line-name,
.member-name,
.family-name,
.person-name,
.lot-name{
  font-weight:1000;
  color:#fff;
}

.item-name{
  font-size:14px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.line-name,
.member-name,
.person-name{
  font-size:16px;
  letter-spacing:-.02em;
}

.family-name{
  font-size:15px;
  letter-spacing:-.02em;
}

.item-sub,
.line-sub,
.member-sub,
.family-sub,
.person-sub{
  margin-top:4px;
  color:var(--mut);
  font-size:12px;
  line-height:1.45;
}

.rarity,
.badge,
.legacy-tag,
.transfer-tag,
.lot-tag,
.room-tag,
.vault-state{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:#fff;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  white-space:nowrap;
}

.rarity,
.badge{
  font-size:11px;
  padding:8px 10px;
}

.meter{
  display:grid;
  gap:10px;
}

.meter-row{
  display:grid;
  grid-template-columns:120px 1fr 58px;
  gap:10px;
  align-items:center;
}

.meter-row.compact{
  grid-template-columns:74px 1fr 48px;
}

.meter-row .lab{
  color:var(--mut);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.track{
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
}

.fill{
  height:100%;
  width:0%;
  border-radius:999px;
  transition:width .25s ease;
  background:linear-gradient(90deg, rgba(115,168,255,.92), rgba(255,111,145,.92));
}

.fill.angel{ background:linear-gradient(90deg, rgba(115,168,255,.88), rgba(168,201,255,.95)); }
.fill.demon{ background:linear-gradient(90deg, rgba(255,111,145,.88), rgba(255,156,120,.95)); }
.fill.null{ background:linear-gradient(90deg, rgba(125,241,223,.88), rgba(190,205,255,.95)); }

.meter-row .val{
  text-align:right;
  font-size:12px;
  font-weight:1000;
}

.tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:14px;
}

.tab{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:#fff;
  border-radius:999px;
  padding:10px 14px;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  cursor:pointer;
}

.tab.is-active{
  background:linear-gradient(90deg, rgba(115,168,255,.18), rgba(255,111,145,.18));
  border-color:rgba(255,255,255,.18);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}

.scene{
  position:relative;
  overflow:hidden;
  min-height:520px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.09);
  background:
    radial-gradient(circle at 15% 20%, rgba(115,168,255,.18), transparent 35%),
    radial-gradient(circle at 80% 0%, rgba(255,111,145,.14), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}

.scene-shell{
  display:none;
  min-height:520px;
}

.scene-shell.is-active{
  display:block;
}

.surface-scene{
  position:relative;
  min-height:520px;
  background:
    linear-gradient(180deg, rgba(34,50,90,.18) 0%, rgba(16,18,28,.25) 25%, rgba(12,14,22,.75) 100%);
}

.surface-skyline{
  position:absolute;
  inset:0 0 auto 0;
  height:44%;
  background:
    radial-gradient(circle at 20% 20%, rgba(115,168,255,.26), transparent 28%),
    radial-gradient(circle at 78% 18%, rgba(255,111,145,.18), transparent 30%);
  pointer-events:none;
}

.surface-floor{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:46%;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.14)),
    linear-gradient(180deg, rgba(40,28,24,.26), rgba(22,18,22,.62));
  border-top:1px solid rgba(255,255,255,.08);
}

.surface-house{
  position:absolute;
  left:50%;
  bottom:90px;
  transform:translateX(-50%);
  width:min(760px, 92%);
  min-height:270px;
  border-radius:28px 28px 18px 18px;
  border:1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
    linear-gradient(180deg, rgba(18,22,36,.95), rgba(9,12,20,.98));
  box-shadow:0 24px 60px rgba(0,0,0,.38);
  overflow:hidden;
}

.surface-house::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, rgba(115,168,255,.9), rgba(255,111,145,.85));
  opacity:.85;
}

.roofline{
  position:absolute;
  left:6%;
  right:6%;
  top:16px;
  height:16px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
}

.room-grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
  padding:44px 18px 18px;
}

.room-tile,
.vault-tile{
  position:relative;
  min-height:92px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  padding:12px;
  overflow:hidden;
}

.vault-tile{
  min-height:120px;
  border-color:rgba(255,255,255,.09);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
}

.vault-tile.locked{
  opacity:.58;
  border-style:dashed;
}

.room-tile::after,
.vault-tile::after{
  content:"";
  position:absolute;
  inset:auto -10% -40% auto;
  width:120px;
  height:120px;
  background:radial-gradient(circle, rgba(255,255,255,.08), transparent 68%);
  pointer-events:none;
}

.room-label,
.vault-name{
  position:relative;
  z-index:1;
  font-size:14px;
  font-weight:1000;
  color:#fff;
}

.room-label{
  font-size:13px;
  letter-spacing:-.02em;
}

.room-sub,
.vault-sub{
  position:relative;
  z-index:1;
  margin-top:4px;
  color:var(--mut);
  font-size:11px;
  line-height:1.45;
}

.room-objects,
.vault-objects,
.lot-tags{
  position:relative;
  z-index:1;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:10px;
}

.room-object-pill,
.vault-object-pill{
  display:inline-flex;
  align-items:center;
  padding:6px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-size:10px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  max-width:100%;
}

.is-common{ background:rgba(255,255,255,.05); }
.is-rare{ background:rgba(115,168,255,.14); }
.is-epic{ background:rgba(255,111,145,.14); }
.is-legendary{ background:rgba(246,208,111,.16); }

.player-stand{
  position:absolute;
  left:50%;
  bottom:32px;
  transform:translateX(-50%);
  width:120px;
  text-align:center;
  z-index:2;
}

.player-avatar-wrap{
  width:88px;
  height:88px;
  margin:0 auto;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 12px 30px rgba(0,0,0,.34);
  overflow:hidden;
}

.player-avatar{
  width:100%;
  height:100%;
  object-fit:cover;
  position:relative;
  z-index:1;
  background:#11182c;
}

.player-name{
  margin-top:8px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.04em;
  color:#fff;
  text-transform:uppercase;
}

.vault-scene{
  position:relative;
  min-height:520px;
  background:
    radial-gradient(circle at 50% 0%, rgba(125,241,223,.10), transparent 26%),
    linear-gradient(180deg, rgba(8,12,18,.92), rgba(3,6,10,.98));
}

.vault-core{
  position:absolute;
  left:50%;
  top:28px;
  transform:translateX(-50%);
  width:min(860px, 94%);
  min-height:440px;
  border-radius:28px;
  border:1px solid rgba(125,241,223,.14);
  background:
    linear-gradient(180deg, rgba(125,241,223,.05), rgba(255,255,255,.02)),
    linear-gradient(180deg, rgba(10,18,22,.95), rgba(6,10,14,.98));
  box-shadow:0 24px 70px rgba(0,0,0,.46);
  overflow:hidden;
}

.vault-core::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg, rgba(125,241,223,.85), rgba(115,168,255,.82));
}

.vault-header{
  padding:18px 18px 10px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

.vault-header .title{
  font-size:16px;
  font-weight:1000;
  letter-spacing:-.02em;
}

.vault-grid{
  padding:0 18px 18px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
}

.note,
.empty,
.warning{
  padding:14px 16px;
  border-radius:16px;
  color:var(--mut);
  font-size:13px;
  line-height:1.55;
}

.note{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
}

.empty{
  border:1px dashed rgba(255,255,255,.14);
  background:rgba(255,255,255,.02);
}

.warning{
  border:1px solid rgba(255,123,147,.22);
  background:rgba(255,123,147,.08);
  color:#fff;
}

#ggSharedPulse,
#ggSharedChain,
#ggSharedAlerts,
#ggAdvisorMount{
  min-width:0;
}

#ggAdvisorMount{
  min-height:220px;
}

@media (max-width:1180px){
  .hero-grid,
  .hero-grid.hero-grid-character{
    grid-template-columns:1fr;
  }

  .span-3,.span-4,.span-5,.span-6,.span-7,.span-8{
    grid-column:span 12;
  }
}

@media (max-width:900px){
  .core-grid,
  .mini-grid,
  .builder-grid,
  .legacy-grid,
  .lot-grid,
  .transfer-grid,
  .room-grid,
  .vault-grid{
    grid-template-columns:1fr;
  }

  .line-member,
  .member,
  .person,
  .family-member{
    grid-template-columns:56px minmax(0,1fr);
  }

  .line-member > .badge,
  .member > .badge,
  .person > .badge,
  .family-member > .badge{
    grid-column:1 / -1;
    justify-self:start;
  }

  .player-avatar-wrap{
    width:72px;
    height:72px;
    border-radius:20px;
  }
}

@media (max-width:720px){
  .wrap{
    padding:14px 12px 64px;
  }

  .hero{
    padding:16px;
    border-radius:24px;
  }

  .hero-title{
    font-size:30px;
  }

  .hero-name{
    font-size:28px;
  }

  .hero-side{
    grid-template-columns:1fr;
  }

  .power-v{
    font-size:32px;
  }

  .meter-row{
    grid-template-columns:88px 1fr 44px;
  }

  .meter-row.compact{
    grid-template-columns:64px 1fr 42px;
  }
}