:root{--bg:#05070c;--panel:#0b1018e8;--panel2:#101827;--gold:#d6b36a;--cyan:#22d3ee;--red:#ef4444;--muted:#9ca3af;--text:#f8fafc;--line:#2b3546;--shadow:0 18px 60px #0009}*{box-sizing:border-box}html,body{margin:0;height:100%;background:radial-gradient(circle at 50% 0,#162033 0,#05070c 45%,#010204 100%);color:var(--text);font-family:Inter,Segoe UI,Roboto,Arial,sans-serif}body:before{content:"";position:fixed;inset:0;background:url('/assets/images/shattered-pantheon-master-4k.webp') center/cover;opacity:.08;filter:blur(8px);pointer-events:none}.shell{position:relative;min-height:100vh}.topbar{height:74px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid #ffffff16;background:linear-gradient(180deg,#0d1420f7,#070b12dc);backdrop-filter:blur(18px);position:sticky;top:0;z-index:50}.brand{display:flex;gap:14px;align-items:center}.brand-mark{width:42px;height:42px;border:1px solid var(--gold);border-radius:50%;display:grid;place-items:center;color:var(--gold);box-shadow:0 0 24px #d6b36a44}.brand h1{font-family:Georgia,serif;margin:0;font-size:22px;letter-spacing:.08em;text-transform:uppercase}.brand small{display:block;color:var(--muted);font-size:12px;letter-spacing:.2em}.nav{display:flex;gap:10px;flex-wrap:wrap}.nav a,.btn{border:1px solid #ffffff18;background:linear-gradient(180deg,#172131,#0b1018);color:#e5e7eb;text-decoration:none;padding:10px 14px;border-radius:12px;font-weight:700;letter-spacing:.06em;cursor:pointer}.nav a:hover,.btn:hover{border-color:var(--gold);box-shadow:0 0 25px #d6b36a22;color:white}.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;padding:34px;align-items:stretch}.hero-card,.panel{border:1px solid #ffffff16;background:linear-gradient(180deg,#101827e8,#060910e8);box-shadow:var(--shadow);border-radius:24px;overflow:hidden}.hero-card{padding:30px;position:relative}.hero-card:after{content:"";position:absolute;right:-80px;top:-80px;width:250px;height:250px;background:radial-gradient(circle,#d6b36a44,transparent 65%)}.kicker{color:var(--gold);text-transform:uppercase;letter-spacing:.22em;font-weight:800;font-size:12px}.hero h2{font-family:Georgia,serif;font-size:54px;line-height:.95;margin:16px 0 14px}.hero p{color:#cbd5e1;line-height:1.7;font-size:17px}.hero-img{min-height:430px;background:url('/assets/images/codex-map-ui-style-reference.webp') center/cover;border-radius:24px;border:1px solid #ffffff18;box-shadow:var(--shadow)}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;padding:0 34px 34px}.card{position:relative;border:1px solid #ffffff16;background:linear-gradient(180deg,#111827,#070b11);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);transition:transform .25s,border-color .25s}.card:hover{transform:translateY(-5px);border-color:var(--gold)}.card img{width:100%;height:190px;object-fit:cover;display:block}.card-body{padding:18px}.card h3{font-family:Georgia,serif;margin:0 0 8px;font-size:22px}.badge{display:inline-flex;align-items:center;gap:6px;border:1px solid #ffffff20;background:#ffffff10;border-radius:999px;padding:5px 9px;color:#e5e7eb;font-size:12px}.codex-layout{display:grid;grid-template-columns:330px 1fr 360px;gap:18px;padding:18px;height:calc(100vh - 74px)}.sidebar,.rightbar{border:1px solid #ffffff16;background:linear-gradient(180deg,#0f1724f4,#060910f4);border-radius:22px;overflow:auto;box-shadow:var(--shadow);padding:18px}.content{overflow:auto;border:1px solid #ffffff16;background:#060910d8;border-radius:22px;box-shadow:var(--shadow)}.search{width:100%;padding:13px 14px;border:1px solid #ffffff20;background:#05070c;color:white;border-radius:14px;margin:10px 0 16px}.entry-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border:1px solid transparent;background:transparent;color:#e5e7eb;text-align:left;border-radius:14px;cursor:pointer}.entry-btn img{width:42px;height:42px;object-fit:contain}.entry-btn:hover,.entry-btn.active{background:#ffffff0d;border-color:#ffffff1a}.entry-hero{height:330px;background:center/cover;position:relative}.entry-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,#060910 0%,transparent 70%)}.entry-copy{padding:26px 30px}.entry-copy h2{font-family:Georgia,serif;font-size:44px;margin:0}.entry-copy p{line-height:1.75;color:#d1d5db}.list{display:grid;gap:10px}.list div{padding:12px;border:1px solid #ffffff13;background:#ffffff09;border-radius:14px}.map-page{height:calc(100vh - 74px);display:grid;grid-template-columns:340px 1fr 360px;gap:14px;padding:14px}.map-wrap{position:relative;overflow:hidden;border:1px solid #ffffff1b;border-radius:22px;box-shadow:var(--shadow);background:#05070c}.map{height:100%;width:100%}.leaflet-container{background:#05070c;font-family:inherit}.map-panel h3,.sidebar h3,.rightbar h3{font-family:Georgia,serif;letter-spacing:.04em;margin:0 0 14px}.layer-row{display:flex;justify-content:space-between;align-items:center;border:1px solid #ffffff15;background:#ffffff08;border-radius:14px;margin:8px 0;padding:10px 12px}.layer-row input{accent-color:var(--gold)}.faction-marker{width:86px;height:86px;display:grid;place-items:center;border-radius:50%;filter:drop-shadow(0 0 14px currentColor)}.faction-marker img{max-width:78px;max-height:78px;object-fit:contain}.faction-marker:before{content:"";position:absolute;width:86px;height:86px;border:2px solid currentColor;border-radius:50%;animation:pulse 1.8s infinite}.npc-marker{width:38px;height:38px;display:grid;place-items:center}.npc-marker img{width:38px;height:38px;object-fit:contain}.resource-marker,.quest-marker,.spawn-marker{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;border:1px solid #fff5;background:#111827;color:white;box-shadow:0 0 16px #000}.resource-marker{color:#facc15}.spawn-marker{color:#22c55e}.quest-marker{color:#a78bfa}.territory{border-radius:50%;border:2px dashed #d6b36a;background:#d6b36a18;box-shadow:0 0 25px #d6b36a33}.tidal{border-radius:50%;border:2px solid #22d3ee;background:#22d3ee16;box-shadow:0 0 35px #22d3ee55;animation:tide 3s ease-in-out infinite}.hover-card{min-width:260px}.hover-card h4{margin:0 0 6px;font-family:Georgia,serif;color:var(--gold)}.hover-card p{margin:0 0 8px;color:#d1d5db;line-height:1.4}.hover-card ul{margin:8px 0 0;padding-left:18px}.admin-layout{display:grid;grid-template-columns:320px 1fr;gap:16px;padding:20px}.editor{width:100%;height:70vh;background:#05070c;color:#d1d5db;border:1px solid #ffffff20;border-radius:16px;padding:16px;font-family:Consolas,monospace}.notice{border:1px solid #d6b36a44;background:#d6b36a12;border-radius:16px;padding:14px;color:#fef3c7}.fade-in{animation:fade .5s ease both}@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes pulse{0%{transform:scale(.85);opacity:.8}70%{transform:scale(1.35);opacity:0}100%{opacity:0}}@keyframes tide{50%{filter:brightness(1.3)}}@media(max-width:1100px){.hero,.codex-layout,.map-page,.admin-layout{grid-template-columns:1fr;height:auto}.grid{grid-template-columns:1fr 1fr}.map-page{height:auto}.map-wrap{height:70vh}}@media(max-width:700px){.grid{grid-template-columns:1fr}.hero h2{font-size:38px}.topbar{height:auto;align-items:flex-start;gap:12px;flex-direction:column}.nav{width:100%}}


/* === Codex vNext AAA Immersion Upgrade === */
:root{--bg:#05070a;--panel:#0b1018;--panel2:#101722;--gold:#d6b06a;--text:#e8edf5;--muted:#9ba7b7;--danger:#ef4444;}
*{box-sizing:border-box} body{margin:0;background:radial-gradient(circle at top,#142033 0,#05070a 38%,#020305 100%);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif;}
a{color:inherit;text-decoration:none}.topbar{position:sticky;top:0;z-index:20;height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:rgba(3,6,10,.82);backdrop-filter:blur(16px);border-bottom:1px solid rgba(214,176,106,.22)}.brand{display:flex;gap:12px;align-items:center}.brand-mark{color:var(--gold);font-size:24px;filter:drop-shadow(0 0 10px rgba(214,176,106,.65))}.brand small{display:block;color:var(--muted);font-size:12px;letter-spacing:.18em;text-transform:uppercase}.topbar nav{display:flex;gap:10px}.topbar nav a{padding:10px 14px;border:1px solid rgba(214,176,106,.18);border-radius:999px;color:#cbd5e1}.topbar nav a.active,.topbar nav a:hover{background:rgba(214,176,106,.14);color:#fff;border-color:rgba(214,176,106,.55)}
.hero{min-height:520px;display:grid;place-items:center;position:relative;overflow:hidden}.hero-bg{position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,7,10,.78),rgba(5,7,10,.35)),url('/assets/images/shattered-pantheon-master-4k.webp') center/cover;animation:slowZoom 24s ease-in-out infinite alternate}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 20%,rgba(214,176,106,.22),transparent 28%),linear-gradient(0deg,#05070a 0,transparent 35%)}.hero-content{position:relative;z-index:1;max-width:960px;padding:52px;text-align:center}.kicker{color:var(--gold);letter-spacing:.22em;text-transform:uppercase;font-size:12px;font-weight:800}.hero h1{font-size:clamp(40px,6vw,78px);line-height:.94;margin:8px 0 20px;text-shadow:0 10px 50px rgba(0,0,0,.8)}.hero p{font-size:18px;color:#d6deeb;line-height:1.7}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(214,176,106,.35);border-radius:12px;padding:12px 18px;background:rgba(10,15,22,.72);color:#fff;box-shadow:0 12px 32px rgba(0,0,0,.25);cursor:pointer}.btn.primary{background:linear-gradient(135deg,#9a6b28,#f0c573);color:#111827;font-weight:900}.btn.small{padding:8px 12px;font-size:13px}.hero-actions{display:flex;gap:14px;justify-content:center;margin-top:26px}.shell{max-width:1500px;margin:0 auto;padding:38px 26px 72px}.section-head{max-width:900px}.section-head h2{font-size:36px;margin:6px 0}.toolrow{display:flex;gap:16px;align-items:center;justify-content:space-between;margin:26px 0;flex-wrap:wrap}.search,select,input[type=file]{width:100%;background:rgba(8,12,18,.92);border:1px solid rgba(214,176,106,.25);border-radius:12px;color:#fff;padding:13px 14px}.toolrow .search{max-width:520px}.filters{display:flex;gap:8px;flex-wrap:wrap}.chip{border:1px solid rgba(214,176,106,.25);background:rgba(9,13,20,.7);color:#dbe4f0;border-radius:999px;padding:9px 13px;cursor:pointer}.chip.active,.chip:hover{background:rgba(214,176,106,.16);border-color:rgba(214,176,106,.65);color:#fff}.codex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}.codex-card{min-height:390px;border:1px solid rgba(214,176,106,.22);border-radius:24px;background-size:cover;background-position:center;overflow:hidden;position:relative;transform-style:preserve-3d;transition:transform .32s ease,border-color .32s,box-shadow .32s;box-shadow:0 18px 50px rgba(0,0,0,.42)}.codex-card:hover{transform:perspective(900px) rotateX(3deg) rotateY(-3deg) translateY(-8px) scale(1.02);border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 45%,transparent),0 30px 90px rgba(0,0,0,.62),0 0 36px color-mix(in srgb,var(--accent) 35%,transparent)}.card-shine{position:absolute;inset:-60%;background:linear-gradient(105deg,transparent 42%,rgba(255,255,255,.18),transparent 58%);transform:translateX(-40%) rotate(12deg);transition:transform .8s}.codex-card:hover .card-shine{transform:translateX(42%) rotate(12deg)}.card-logo{position:absolute;top:18px;right:18px;width:86px;height:86px;object-fit:contain;filter:drop-shadow(0 0 16px var(--accent));animation:logoFloat 3.5s ease-in-out infinite}.card-body{position:absolute;left:0;right:0;bottom:0;padding:26px;background:linear-gradient(0deg,rgba(4,6,9,.96),rgba(4,6,9,.72),transparent)}.card-body h3{font-size:27px;margin:5px 0 10px}.card-body p{color:#cbd5e1;line-height:1.55}.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}.reveal.in,.reveal{opacity:1;transform:none}@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.08)}}@keyframes logoFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-5px) scale(1.035)}}
.entry-page{display:grid;grid-template-columns:310px 1fr 330px;grid-template-rows:72px calc(100vh - 72px);height:100vh;overflow:hidden}.entry-page .topbar{grid-column:1/4}.entry-sidebar,.entry-facts{overflow:auto;background:rgba(5,8,13,.92);border-right:1px solid rgba(214,176,106,.16);padding:18px}.entry-facts{border-right:0;border-left:1px solid rgba(214,176,106,.16)}.entry-content{overflow:auto;background:#05070a}.entry-list{display:grid;gap:10px;margin-top:14px}.entry-btn{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:rgba(16,23,34,.72);border:1px solid rgba(214,176,106,.14);border-radius:14px;color:#fff;padding:10px;cursor:pointer}.entry-btn.active,.entry-btn:hover{border-color:rgba(214,176,106,.65);background:rgba(214,176,106,.10)}.entry-btn img{width:44px;height:44px;object-fit:contain;flex:0 0 auto}.entry-hero{min-height:440px;background-size:cover;background-position:center;display:flex;align-items:end;gap:24px;padding:44px;position:relative;overflow:hidden}.entry-hero:after{content:"";position:absolute;inset:0;border-bottom:1px solid color-mix(in srgb,var(--accent) 45%,transparent);box-shadow:inset 0 -80px 120px #05070a}.entry-hero>*{position:relative;z-index:1}.entry-logo{width:150px;height:150px;object-fit:contain;filter:drop-shadow(0 0 26px var(--accent));animation:logoFloat 4s infinite ease-in-out}.entry-hero h1{font-size:clamp(42px,5vw,76px);margin:0;text-shadow:0 10px 40px #000}.entry-copy{max-width:1050px;padding:36px 46px 80px}.entry-copy section{background:rgba(13,19,29,.65);border:1px solid rgba(214,176,106,.18);border-radius:18px;margin:18px 0;padding:22px;box-shadow:0 16px 40px rgba(0,0,0,.24)}.entry-copy h3{color:var(--gold);letter-spacing:.08em;text-transform:uppercase}.entry-copy p{line-height:1.8;color:#d5deeb}.list{display:grid;gap:10px}.list>div,.ornate-list>div{padding:12px 14px;background:rgba(255,255,255,.04);border:1px solid rgba(214,176,106,.14);border-radius:12px}.hover-term{border-bottom:1px dotted var(--gold);color:#fff;position:relative;cursor:help}.hover-term:hover:after{content:attr(data-tip);position:absolute;left:0;bottom:1.5em;width:280px;background:#09111d;border:1px solid rgba(214,176,106,.6);border-radius:12px;padding:12px;color:#dbeafe;z-index:5;box-shadow:0 20px 60px rgba(0,0,0,.55)}.audio-panel{background:linear-gradient(180deg,rgba(214,176,106,.10),rgba(12,17,25,.8));border:1px solid rgba(214,176,106,.28);border-radius:18px;padding:16px;margin-bottom:18px}.audio-title{font-weight:900;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;font-size:12px}.audio-status{color:#b7c3d4;font-size:13px;line-height:1.5;margin:10px 0}.audio-controls{display:flex;gap:8px}.audio-controls button{flex:1;background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(214,176,106,.22);border-radius:10px;padding:10px;cursor:pointer}.footer{padding:30px;text-align:center;color:#9ba7b7;border-top:1px solid rgba(214,176,106,.16)}
.admin-shell{max-width:1400px;margin:0 auto;padding:34px}.admin-panel,.editor-wrap{background:rgba(10,15,23,.82);border:1px solid rgba(214,176,106,.22);border-radius:22px;padding:22px;margin-bottom:18px}.admin-tabs{display:flex;gap:8px;margin-top:16px}.admin-grid{display:grid;grid-template-columns:230px 1fr;gap:18px}.file-list{display:grid;gap:8px;align-content:start}.file-list button{background:rgba(16,23,34,.75);border:1px solid rgba(214,176,106,.18);color:#fff;border-radius:12px;padding:12px;text-align:left;cursor:pointer}.file-list button.active,.file-list button:hover{border-color:var(--gold);background:rgba(214,176,106,.12)}textarea#editor{width:100%;min-height:58vh;background:#05070a;color:#dbeafe;border:1px solid rgba(214,176,106,.22);border-radius:14px;padding:16px;font-family:Consolas,monospace;font-size:13px;line-height:1.5}.hidden{display:none!important}.script-box pre{white-space:pre-wrap;background:#05070a;border:1px solid rgba(214,176,106,.18);border-radius:14px;padding:16px;color:#dbeafe;line-height:1.55}.status{margin-top:14px;color:#bbf7d0}.faction-marker img,.marker img,.map-marker img{object-fit:contain!important;overflow:visible!important;clip-path:none!important}.map-marker,.faction-marker{overflow:visible!important}
@media(max-width:1050px){.entry-page{display:block;height:auto;overflow:auto}.entry-sidebar,.entry-facts{max-height:none;border:0}.entry-content{overflow:visible}.entry-page .topbar{position:sticky}.entry-hero{min-height:360px;padding:28px}.entry-logo{width:110px;height:110px}.admin-grid{grid-template-columns:1fr}.topbar{height:auto;min-height:72px;align-items:flex-start;gap:12px;flex-direction:column;padding:14px}.topbar nav{flex-wrap:wrap}.hero-content{padding:30px}.toolrow{align-items:stretch}}

/* vNext.1 AAA logo overhaul: static, centered, non-clipped faction crests. */
.codex-card .card-logo-frame{
  position:absolute;
  top:18px;
  right:18px;
  width:104px;
  height:104px;
  display:grid;
  place-items:center;
  padding:10px;
  border-radius:18px;
  overflow:visible;
  background:linear-gradient(145deg,rgba(8,11,15,.94),rgba(20,25,34,.78));
  border:1px solid color-mix(in srgb,var(--accent) 42%,rgba(255,255,255,.10));
  box-shadow:0 16px 36px rgba(0,0,0,.62), inset 0 0 22px rgba(255,255,255,.035);
  z-index:3;
}
.codex-card .card-logo{
  position:static!important;
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  filter:drop-shadow(0 5px 10px rgba(0,0,0,.82));
  animation:none!important;
  transform:none!important;
  display:block;
}
.codex-card:hover .card-logo-frame{
  transform:translateY(-2px) scale(1.025);
  transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease;
  border-color:color-mix(in srgb,var(--accent) 62%,rgba(255,255,255,.18));
  box-shadow:0 18px 44px rgba(0,0,0,.72),0 0 26px color-mix(in srgb,var(--accent) 26%,transparent),inset 0 0 22px rgba(255,255,255,.04);
}
.entry-logo{
  width:154px!important;
  height:154px!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:12px;
  border-radius:22px;
  background:linear-gradient(145deg,rgba(8,11,15,.85),rgba(20,25,34,.65));
  border:1px solid color-mix(in srgb,var(--accent) 40%,rgba(255,255,255,.08));
  filter:drop-shadow(0 10px 22px rgba(0,0,0,.78));
  animation:none!important;
}
.entry-list-logo{
  width:52px;
  height:52px;
  flex:0 0 52px;
  display:grid;
  place-items:center;
  border-radius:12px;
  padding:5px;
  background:rgba(4,8,13,.55);
  border:1px solid rgba(214,176,106,.18);
  overflow:visible;
}
.entry-list-logo img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  object-position:center!important;
  animation:none!important;
  filter:drop-shadow(0 3px 7px rgba(0,0,0,.75));
}
.faction-logo img,.faction-icon img,.map-marker img,.faction-marker img{
  width:100%;
  height:100%;
  object-fit:contain!important;
  object-position:center center!important;
  animation:none!important;
  clip-path:none!important;
}


/* === FINAL AAA Logo Overhaul Lock ===
   No pulsing logo animations, no clipped icons, no temporary letter badges.
   All Codex card, entry, sidebar, and map logos use static high-quality centered crest PNGs. */
.card-logo,.entry-logo,.entry-btn img,.entry-list-logo img,.faction-marker img,.npc-marker img,.map-marker img{animation:none!important;object-fit:contain!important;object-position:center!important;clip-path:none!important;}
.codex-card .card-logo-frame{overflow:visible!important;display:grid!important;place-items:center!important;padding:9px!important;}
.codex-card .card-logo{position:static!important;width:100%!important;height:100%!important;max-width:100%!important;max-height:100%!important;}
.entry-logo{overflow:visible!important;}
.entry-list-logo{overflow:visible!important;display:grid!important;place-items:center!important;}
.entry-list-logo img{width:100%!important;height:100%!important;}
.faction-marker:before{animation:none!important;opacity:.35!important;}

/* === vNext.2 Final Crest Centering Patch ===
   Keeps every faction logo fully visible, centered, and premium inside the Codex card square. */
.codex-card .card-logo-frame{
  width:118px!important;
  height:118px!important;
  padding:14px!important;
  overflow:hidden!important;
  display:grid!important;
  place-items:center!important;
  border-radius:20px!important;
}
.codex-card .card-logo{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  object-position:50% 50%!important;
  transform:none!important;
  animation:none!important;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.85))!important;
}
.entry-logo,
.entry-list-logo img,
.faction-marker img,
.npc-marker img,
.map-marker img{
  object-fit:contain!important;
  object-position:50% 50%!important;
  transform:none!important;
  animation:none!important;
}

/* === vNext.3 Codex Card Navigation Patch ===
   Entire Codex cards are clickable; Open Codex buttons are intentionally removed. */
a.codex-card{
  display:block;
  color:inherit;
  text-decoration:none;
  cursor:pointer;
}
a.codex-card:focus-visible{
  outline:2px solid var(--accent, #d6b36a);
  outline-offset:4px;
}
a.codex-card .card-body{pointer-events:none;}

/* === vNext.4 Emergency AAA Crest Fix ===
   Restores premium static crest treatment. Uses only full crest images, never cropped cover images.
   Fixes: off-center icons, clipped Forge/Tide logos, tiny icon scaling, and visible baked-card title clutter. */
.codex-grid{
  width:100%;
  max-width:1680px;
  margin:0 auto;
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(310px,1fr))!important;
  gap:26px!important;
}
.codex-card{
  min-height:430px!important;
  overflow:hidden!important;
  isolation:isolate;
}
.codex-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background:linear-gradient(180deg,rgba(2,5,8,.70),rgba(2,5,8,.42) 38%,rgba(2,5,8,.98) 100%);
  pointer-events:none;
}
.codex-card .card-shine,
.codex-card .card-logo-frame,
.codex-card .card-body{position:absolute;z-index:2;}
.codex-card .card-logo-frame{
  top:18px!important;
  right:18px!important;
  width:148px!important;
  height:148px!important;
  padding:8px!important;
  display:grid!important;
  place-items:center!important;
  overflow:hidden!important;
  border-radius:22px!important;
  background:linear-gradient(145deg,rgba(6,10,15,.92),rgba(15,22,33,.78))!important;
  border:1px solid color-mix(in srgb,var(--accent,#d6b36a) 48%,rgba(255,255,255,.16))!important;
  box-shadow:0 18px 44px rgba(0,0,0,.72), inset 0 0 28px rgba(255,255,255,.035)!important;
}
.codex-card .card-logo{
  position:static!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  transform:none!important;
  animation:none!important;
  clip-path:none!important;
  filter:drop-shadow(0 8px 14px rgba(0,0,0,.88))!important;
}
.codex-card:hover .card-logo-frame{
  transform:none!important;
}
.codex-card .card-body{
  left:0!important;
  right:0!important;
  bottom:0!important;
  z-index:3!important;
  padding:30px 28px!important;
  background:linear-gradient(0deg,rgba(3,6,10,.98),rgba(3,6,10,.86) 62%,transparent)!important;
}
.card-logo,.entry-logo,.entry-btn img,.entry-list-logo img,.faction-marker img,.npc-marker img,.map-marker img{
  animation:none!important;
  object-fit:contain!important;
  object-position:center center!important;
  clip-path:none!important;
}
@media(max-width:760px){
  .codex-card .card-logo-frame{width:124px!important;height:124px!important;}
  .codex-grid{grid-template-columns:1fr!important;}
}

/* === vNext.5 Studio Card Presentation Controls ===
   Non-regressive fix: logos are larger, centered, non-clipped, and editable from Admin.
   Card background visibility is improved and also editable per Codex card. */
.codex-card{
  background-image:var(--card-bg)!important;
  background-size:cover!important;
  background-position:center!important;
}
.codex-card::before{
  background:linear-gradient(180deg,
    rgba(2,5,8,calc(var(--card-bg-opacity,.74) * .78)),
    rgba(2,5,8,calc(var(--card-bg-opacity,.74) * .48)) 42%,
    rgba(2,5,8,calc(var(--card-bg-opacity,.74) * 1.18)) 100%)!important;
}
.codex-card .card-logo-frame{
  width:160px!important;
  height:160px!important;
  padding:12px!important;
  overflow:hidden!important;
  transform:scale(var(--logo-frame-scale,1))!important;
  transform-origin:center!important;
}
.codex-card .card-logo{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  transform:translate(var(--logo-x,0px),var(--logo-y,0px)) scale(var(--logo-scale,1.18))!important;
  transform-origin:center center!important;
}
.codex-card:hover .card-logo-frame{
  transform:scale(var(--logo-frame-scale,1))!important;
}
.admin-layout-tool{
  display:grid;
  grid-template-columns:minmax(280px,420px) 1fr;
  gap:22px;
}
.layout-form{
  display:grid;
  gap:14px;
}
.layout-form label{display:grid;gap:7px;color:#dbe4f0;font-size:13px;}
.layout-form input[type=range]{width:100%;accent-color:#d6b06a;}
.layout-preview-wrap{
  display:grid;
  place-items:center;
  min-height:520px;
  background:radial-gradient(circle at 50% 18%,rgba(214,176,106,.10),transparent 34%),rgba(5,8,13,.86);
  border:1px solid rgba(214,176,106,.18);
  border-radius:20px;
  overflow:auto;
  padding:28px;
}
.layout-preview-wrap .codex-card{width:min(380px,90vw);}
.upload-row{display:flex;gap:10px;align-items:end;flex-wrap:wrap;}
.status.good{color:#9ae6b4}.status.warn{color:#f6c177}
@media(max-width:950px){.admin-layout-tool{grid-template-columns:1fr}.codex-card .card-logo-frame{width:136px!important;height:136px!important;}}

/* === Auth + Final AAA Presentation System === */
.discord-auth-badge{display:flex;align-items:center;gap:10px;margin-left:16px;border:1px solid rgba(88,101,242,.55);background:linear-gradient(135deg,rgba(88,101,242,.22),rgba(10,15,24,.82));border-radius:999px;padding:7px 10px;box-shadow:0 12px 32px rgba(0,0,0,.38),0 0 22px rgba(88,101,242,.18);color:#fff;min-height:46px}.discord-auth-badge a{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none}.discord-auth-badge img{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.22)}.discord-auth-badge b{display:block;font-size:12px;letter-spacing:.05em;text-transform:uppercase}.discord-auth-badge small{display:block;color:#cbd5ff;font-size:10px;line-height:1.1}.discord-dot{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:#5865f2;box-shadow:0 0 18px rgba(88,101,242,.65)}.logout-mini{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;border-radius:999px;padding:6px 9px;cursor:pointer}.admin-only[hidden]{display:none!important}.admin-auth-warning{border:1px solid rgba(88,101,242,.44)!important;background:linear-gradient(135deg,rgba(88,101,242,.16),rgba(10,15,24,.88))!important}.admin-divider{border:0;border-top:1px solid rgba(214,176,106,.2);width:100%;margin:10px 0}.mini-note{font-size:12px;color:#aab5c7;line-height:1.55;margin:0 0 6px}.codex-card{background-size:var(--card-bg-size,cover)!important;background-position:var(--card-bg-x,50%) var(--card-bg-y,50%)!important}.codex-card .card-logo-frame{width:174px!important;height:174px!important;padding:10px!important}.codex-card .card-logo{transform:translate(var(--logo-x,0px),var(--logo-y,0px)) scale(var(--logo-scale,1.22))!important}.entry-logo-frame{width:176px;height:176px;display:grid;place-items:center;padding:12px;border-radius:24px;background:linear-gradient(145deg,rgba(8,11,15,.88),rgba(20,25,34,.68));border:1px solid color-mix(in srgb,var(--accent,#d6b36a) 44%,rgba(255,255,255,.12));box-shadow:0 22px 48px rgba(0,0,0,.62);transform:scale(var(--page-logo-frame-scale,1));flex:0 0 auto}.entry-logo-frame .entry-logo{position:static!important;width:100%!important;height:100%!important;padding:0!important;border:0!important;background:transparent!important;object-fit:contain!important;transform:translate(var(--page-logo-x,0px),var(--page-logo-y,0px)) scale(var(--page-logo-scale,1))!important;filter:drop-shadow(0 10px 18px rgba(0,0,0,.86))!important}.entry-preview{width:100%;min-height:190px;margin-top:22px;background-size:cover;background-position:center;border:1px solid rgba(214,176,106,.22);border-radius:20px;display:flex;align-items:center;gap:18px;padding:20px;box-shadow:0 18px 42px rgba(0,0,0,.38)}.entry-preview h3{font-size:28px;margin:5px 0;color:var(--accent,#d6b06a)}.entry-preview .entry-logo-frame{width:128px;height:128px}.layout-preview-wrap{grid-template-columns:1fr!important}.layout-preview-wrap .codex-card{width:min(430px,92vw)}
@media(max-width:1050px){.discord-auth-badge{margin-left:0}.entry-logo-frame{width:132px;height:132px}.codex-card .card-logo-frame{width:144px!important;height:144px!important}}
.auth-status-banner{margin:0 0 16px;padding:12px 14px;border:1px solid rgba(88,101,242,.55);background:linear-gradient(135deg,rgba(88,101,242,.18),rgba(10,15,24,.88));color:#eef2ff;border-radius:14px;box-shadow:0 12px 34px rgba(0,0,0,.34)}

/* Admin Website Social Preview Editor */
.social-preview-admin{display:grid;grid-template-columns:minmax(320px,420px) 1fr;gap:22px;align-items:start}.social-form{display:grid;gap:10px}.social-textarea{min-height:120px;resize:vertical;font-family:inherit}.social-actions{display:flex;gap:10px;flex-wrap:wrap}.social-preview-stack{display:grid;gap:14px}.social-canvas{width:100%;max-width:720px;aspect-ratio:1200/630;height:auto;border:1px solid rgba(214,176,106,.24);border-radius:18px;background:#05070c;box-shadow:0 18px 44px rgba(0,0,0,.45)}.social-card-preview{max-width:560px;background:#2b2d31;border-left:4px solid #5865f2;border-radius:8px;overflow:hidden;box-shadow:0 18px 44px rgba(0,0,0,.38);color:#f2f3f5}.social-card-image-wrap{width:100%;aspect-ratio:1200/630;background:#111;overflow:hidden}.social-card-image-wrap img{width:100%;height:100%;object-fit:cover;display:block}.social-card-body{padding:14px 16px 16px;display:grid;gap:6px}.social-card-body small{color:#b5bac1;text-transform:lowercase}.social-card-body b{color:#00a8fc;font-size:16px;line-height:1.25}.social-card-body p{margin:0;color:#dbdee1;line-height:1.45}.social-preview-admin input[type="range"]{accent-color:var(--gold)}@media(max-width:1000px){.social-preview-admin{grid-template-columns:1fr}.social-canvas{max-width:100%}}
