@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root{
  --brandBlue: #1098e8; /* Monstryx blue */

  --bg0:#05070f;
  --bg1:#070a12;
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);
  --faint: rgba(255,255,255,.55);
  --line: rgba(255,255,255,.10);
  --glass: rgba(255,255,255,.06);
  --glass2: rgba(255,255,255,.10);
  --shadow: 0 20px 60px rgba(0,0,0,.45);
  --shadow2: 0 10px 26px rgba(0,0,0,.35);
  --radius: 22px;
  --radius2: 28px;
  --max: 1120px;
  --accentA: rgba(255,122,50,.92);   /* ember */
  --accentB: rgba(120,190,255,.92);  /* frost */
  --accentC: rgba(170,120,255,.70);  /* mystic */
  --font: 'Inter', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color: var(--text);
  background: #070a12;
  line-height:1.6;
}

body.page-home{background-image:url('backgrounds/home.svg');}
body.page-types{background-image:url('backgrounds/types.svg');}
body.page-characters{background-image:url('backgrounds/characters.svg');}
body.page-creature{background-image:url('backgrounds/creature.svg');}
body.page-home, body.page-types, body.page-characters, body.page-creature{
  background-size: cover;
  background-position: center top;
  background-attachment: fixed;
}


a{color:inherit}
.wrap{margin:0 0 10px; color: rgba(255,255,255,.78);}

header{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  background: rgba(5,7,15,.55);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.headerInner{
  max-width:var(--max);
  margin:0 auto;
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.brand{display:flex; align-items:center; gap:12px; text-decoration:none;}
.mark{
  width:44px; height:44px;
  border-radius:14px;
  background: rgba(12,16,28,.85);
  border:1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow2);
  display:grid; place-items:center;
}

.brandTitle{display:flex; flex-direction:column; line-height:1.1}
.brandTitle b{letter-spacing:1.1px; font-size:14px}
.brandTitle span{font-size:12px; color:rgba(255,255,255,.62)}

nav{display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; align-items:center}
nav a{
  text-decoration:none;
  padding:9px 11px;
  border-radius:999px;
  color:rgba(255,255,255,.72);
  border:1px solid transparent;
}
nav a:hover{background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.10); color:var(--text)}
.navCta{
  background: rgba(12,16,28,.85);
  border-color: rgba(16,152,232,.40);
  font-weight:600;
  color: rgba(255,255,255,.92);
}

.navCta:hover{background: rgba(255,255,255,.10);}

main{padding-top:22px}

.hero{
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius2);
  background:
    radial-gradient(1200px 800px at 18% 0%, rgba(255,122,50,.22), transparent 55%),
    radial-gradient(900px 650px at 85% 0%, rgba(120,190,255,.18), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  padding: 44px 40px;
  overflow:hidden;
  position:relative;
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto -180px -220px auto;
  width:520px; height:520px;
  background: radial-gradient(circle at 30% 30%, rgba(170,120,255,.18), transparent 62%);
  transform: rotate(-12deg);
}
.kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:2px;
  color:rgba(255,255,255,.64);
  margin:0 0 12px;
}
.kickerDot{
  width:8px; height:8px; border-radius:50%;
  background: rgba(16,152,232,.98);
  box-shadow: 0 0 0 6px rgba(255,255,255,.03);
}

h1{
  margin:0 0 14px;
  font-size: clamp(44px, 6vw, 68px);
  line-height:1.02;
  letter-spacing:-1px;
}
.sub{
  margin:0 0 22px;
  max-width: 72ch;
  font-size: clamp(16px, 2.2vw, 20px);
  color: rgba(255,255,255,.72);
}

.ctaRow{display:flex; gap:12px; flex-wrap:wrap; margin-top:10px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  text-decoration:none;
  font-weight:650;
  color: rgba(255,255,255,.92);
  transition: transform .12s ease, background .12s ease;
}
.btn:hover{background: rgba(255,255,255,.10); transform: translateY(-1px);}
.btn.primary{
  border-color: rgba(255,255,255,.10);
  background: rgba(16,152,232,.92);
  color: #071018;
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
}
.btn.primary:hover{background: rgba(16,152,232,1.0);}

.grid{display:grid; grid-template-columns: repeat(12, 1fr); gap:16px; margin-top:18px;}
.card{
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  background: rgba(10,14,24,.72);
  padding: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.28);
}

.card:hover{border-color: rgba(255,255,255,.14);}
.span6{grid-column: span 6;}
.span12{grid-column: span 12;}
h2{margin:0 0 10px; font-size: 22px; letter-spacing:-.3px}
h3{margin:0; font-size: 18px; letter-spacing:-.2px}
p{margin:0 0 10px; color: rgba(255,255,255,.68);}
.small{color: rgba(255,255,255,.60); font-size:13px}
.divider{height:1px; background: rgba(255,255,255,.10); margin:14px 0 0;}

/* Types */
.typesGrid{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px; margin-top:16px;}
.typeCard{padding:18px;}
.typeTop{display:flex; align-items:center; gap:10px}
.typeTop img{width:16px; height:16px; border-radius:6px; opacity:.95}
.pill{font-size:12px; padding:7px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12);
background: rgba(255,255,255,.04); color: rgba(255,255,255,.78);}
.metaRow{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px;}

/* Characters roster */
.rosterGrid{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px; margin-top:16px;}
.rosterCard a{text-decoration:none; display:block}
.rosterTop{display:flex; align-items:center; justify-content:space-between; gap:10px;}
.badge{font-size:11px; padding:7px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12);
background: rgba(255,255,255,.05); color: rgba(255,255,255,.80); white-space:nowrap;}
.subtitle{color: rgba(255,255,255,.80); font-size:13px; margin-top:8px;}
.tags{color: rgba(255,255,255,.55); font-size:12px; margin-top:10px;}
.bio{color: rgba(255,255,255,.68); font-size:13px; margin-top:12px;}

/* Creature page */
.creatureHero{display:flex; gap:18px; align-items:flex-start; flex-wrap:wrap;}
.creatureHero img.portrait{width:340px; max-width:100%; border-radius: var(--radius);
border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.04); box-shadow: var(--shadow2);}
.creatureMeta{flex:1 1 340px;}

/* Footer */
footer{
  margin-top:34px;
  color: rgba(255,255,255,.55);
  font-size:12px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
  padding-top:18px;
  border-top: 1px solid rgba(255,255,255,.08);
}
footer a{color: rgba(255,255,255,.70); text-decoration:none;}
footer a:hover{text-decoration:underline;}

/* Responsive */
@media (max-width: 980px){
  .typesGrid, .rosterGrid{grid-template-columns: repeat(2, minmax(0, 1fr));}
  .hero{padding:38px 26px;}
}
@media (max-width: 720px){
  nav{justify-content:flex-start}
  .span6{grid-column: span 12;}
  .typesGrid, .rosterGrid{grid-template-columns: 1fr;}
  h1{letter-spacing:-.6px;}
}

/* Product-launch sections */
.sectionTitle{
  display:flex; align-items:baseline; justify-content:space-between; gap:14px; flex-wrap:wrap;
}
.sectionTitle h2{font-size:26px}
.metrics{
  display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:12px; margin-top:14px;
}
.metric{
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  background: rgba(255,255,255,.05);
  padding:14px;
}
.metric .num{font-size:22px; font-weight:750; letter-spacing:-.4px}
.metric .lbl{font-size:12px; letter-spacing:1.6px; text-transform:uppercase; color:rgba(255,255,255,.62); margin-top:6px}
.featureGrid{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px; margin-top:16px;
}
.feature{
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  background: rgba(255,255,255,.05);
  padding:18px;
}
.feature .icon{
  width:44px; height:44px; border-radius:14px;
  background: rgba(12,16,28,.85);
  border: 1px solid rgba(255,255,255,.14);
  display:grid; place-items:center;
  color: rgba(16,152,232,.98);
  font-weight:800;
  box-shadow: var(--shadow2);
  margin-bottom:12px;
}

.mediaGrid{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px; margin-top:16px;
}
.mediaTile{
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  background: rgba(255,255,255,.04);
  overflow:hidden;
}
.mediaTile .img{
  aspect-ratio: 16/10;
  background:
    radial-gradient(800px 500px at 20% 10%, rgba(255,122,50,.20), transparent 55%),
    radial-gradient(700px 500px at 85% 0%, rgba(120,190,255,.18), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
}
.mediaTile .cap{padding:14px}
.roadmap{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px; margin-top:16px;
}
.step{
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  background: rgba(255,255,255,.05);
  padding:18px;
}
.step .tag{
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; letter-spacing:1.6px; text-transform:uppercase;
  color:rgba(255,255,255,.65);
}
.step .tag .dot{width:8px;height:8px;border-radius:50%;background: rgba(16,152,232,.98);}
@media (max-width: 980px){
  .metrics{grid-template-columns: repeat(2, minmax(0,1fr));}
  .featureGrid,.mediaGrid,.roadmap{grid-template-columns: repeat(2, minmax(0,1fr));}
}
@media (max-width: 720px){
  .metrics,.featureGrid,.mediaGrid,.roadmap{grid-template-columns: 1fr;}
}


/* Brand logo integration */
.mark img{
  width: 28px;
  height: 28px;
  object-fit: contain;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.35));
}
/* Subtle monogram pattern overlay across pages */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .07;
  background-image: url('brand/monstryx-m-128.png');
  background-repeat: repeat;
  background-size: 140px auto;
  background-position: 20px 20px;
  mix-blend-mode: screen;
  transform: rotate(-8deg) scale(1.06);
}
@media (max-width: 720px){
  body::before{opacity:.05; background-size: 160px auto;}
}

body::after{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background: rgba(5,7,15,.62);
  z-index: -1;
}


/* Hero title backgrounds */
.hero{
  position: relative;
  background-image: url('backgrounds/hero-home.svg');
  background-size: cover;
  background-position: center;
}
.page-types .hero{background-image: url('backgrounds/hero-types.svg');}
.page-characters .hero{background-image: url('backgrounds/hero-characters.svg');}

/* Dark scrim for hero readability */
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(5,7,15,.55);
  pointer-events:none;
}
.hero > *{position: relative; z-index:1;}

.filters{display:flex; gap:8px; flex-wrap:wrap; margin-top:12px}
.chip{font-size:12px;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);color:rgba(255,255,255,.82);cursor:pointer;user-select:none}
.chip.active{background:rgba(16,152,232,.18);border-color:rgba(16,152,232,.45)}

/* View toggle */
.viewToggle{display:flex; gap:8px; margin-top:10px; flex-wrap:wrap}
.viewBtn{
  font-size:12px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.82);
  cursor:pointer;
}
.viewBtn.active{background:rgba(16,152,232,.18);border-color:rgba(16,152,232,.45);}

/* Card flip + rarity frames */
.flip{position:relative; width:100%; aspect-ratio: 2 / 3; perspective: 900px;}
.flipInner{position:absolute; inset:0; transform-style: preserve-3d; transition: transform .55s ease;}
.flipFace{position:absolute; inset:0; backface-visibility:hidden; border-radius:18px; overflow:hidden;}
.flipBack{transform: rotateY(180deg);}
/* Flip only in Card View */
.rosterCard.cardView .flip:hover .flipInner{transform: rotateY(180deg);}

/* Rarity frames (subtle, modern) */
.rosterCard.cardView .flipFace{border:2px solid rgba(255,255,255,.10);}
.rosterCard.cardView[data-rarity="Common"] .flipFace{border-color: rgba(16,152,232,.38);}
.rosterCard.cardView[data-rarity="Rare"] .flipFace{border-color: rgba(200,210,225,.45);}
.rosterCard.cardView[data-rarity="Epic"] .flipFace{border-color: rgba(170,120,255,.45);}
.rosterCard.cardView[data-rarity="Mythic"] .flipFace{border-color: rgba(232,198,98,.55);}

/* Card View gallery */
.rosterCard.cardView .rosterTop{display:none;}
.rosterCard.cardView .subtitle,
.rosterCard.cardView .bio,
.rosterCard.cardView .tags,
.rosterCard.cardView .small{display:none;}


/* Character vs Card view toggle on creature pages */
.viewTabs{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}
.tabBtn{
  font-size:12px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.82);
  cursor:pointer;
}
.tabBtn.active{background:rgba(16,152,232,.18);border-color:rgba(16,152,232,.45);}
.viewPane{display:none; margin-top:12px}
.viewPane.active{display:block}
.viewPane img{width:100%; height:auto; display:block; border-radius:18px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.03);}
.missingCardNote{margin-top:10px; color:rgba(255,255,255,.65); font-size:13px}


/* Ensure Character and Card images are identical size on creature pages */
.viewPane{max-width:420px}
.viewPane img{aspect-ratio: 2 / 3; object-fit: cover;}


/* Characters index: separate Character vs Card thumbnails */
.charThumb{width:100%; aspect-ratio: 2 / 3; border-radius:18px; overflow:hidden; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.03);}
.thumbImg{width:100%; height:100%; object-fit:cover; display:block;}
.thumbSpacer{height:12px}

/* Default: show character portrait thumb (characters grid only) */
.rosterCard .flip{display:none;}
/* Card View: show card flip, hide character portrait */
.rosterCard.cardView .charThumb{display:none;}
.rosterCard.cardView .flip{display:block;}

/* Flip behavior (kept) */
.flip{position:relative; width:100%; aspect-ratio: 2 / 3; perspective: 900px;}
.flipInner{position:absolute; inset:0; transform-style: preserve-3d; transition: transform .55s ease;}
.flipFace{position:absolute; inset:0; backface-visibility:hidden; border-radius:18px; overflow:hidden;}
.flipBack{transform: rotateY(180deg);}
.rosterCard.cardView .flip:hover .flipInner{transform: rotateY(180deg);}


/* Creature page: ensure character + card images match size */
.creatureHero .viewPane{
  max-width:420px;
  margin:0 auto;
}
.creatureHero .viewPane > img{
  width:100%;
  aspect-ratio:2/3;
  object-fit:cover;
}

/* Status filter block */
.statusFilters{margin-top:12px}
.statusFilters .small{color:rgba(255,255,255,.60); font-size:13px}

/* Monogram pattern overlay (MMM) */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .07;
  background-image: url('brand/monstryx-m-128.png');
  background-repeat: repeat;
  background-size: 140px auto;
  background-position: 20px 20px;
  mix-blend-mode: screen;
  transform: rotate(-8deg) scale(1.06);
}
@media (max-width: 720px){
  body::before{opacity:.05; background-size: 160px auto;}
}


/* Homepage featured scroller */
.hScroll{display:flex; gap:14px; overflow:auto; padding:10px 2px; scroll-snap-type:x mandatory;}
.hTile{min-width:200px; max-width:220px; text-decoration:none; scroll-snap-align:start;}
.hTile img{width:100%; aspect-ratio:2/3; object-fit:cover; border-radius:18px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.03); display:block;}
.hCap{margin-top:10px; color:rgba(255,255,255,.86);}
.hCap b{display:block; font-size:14px}

/* Characters controls */
.controlsBar{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; align-items:center}
.searchInput{flex:1 1 220px; min-width:220px; padding:10px 12px; border-radius:999px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.05); color:rgba(255,255,255,.92)}
.sortSelect{padding:10px 12px; border-radius:999px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.05); color:rgba(255,255,255,.92)}
.toggleWrap{display:flex; gap:8px; align-items:center; padding:8px 12px; border-radius:999px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.05); color:rgba(255,255,255,.82)}
.toggleWrap input{accent-color: rgba(16,152,232,.9);}

/* Stats */
.statsGrid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; margin-top:10px}
.stat{border:1px solid rgba(255,255,255,.10); border-radius:18px; background:rgba(255,255,255,.04); padding:12px}
.stat .num{font-size:18px; font-weight:750; letter-spacing:-.2px}
.stat .lbl{font-size:12px; letter-spacing:1.4px; text-transform:uppercase; color:rgba(255,255,255,.62); margin-top:6px}


/* Mobile polish: compact header + nav drawer */
@media (max-width: 820px){
  header{position:sticky; top:0; z-index:50; backdrop-filter: blur(10px);}
  .headerInner{padding:10px 14px;}
  .brandTitle span{display:none;}
  nav{gap:8px;}
  nav a{padding:8px 10px; font-size:13px;}
  .navCta{padding:8px 12px;}
  .mark{width:34px;height:34px;border-radius:12px}
}

/* Collapsible nav for small screens */
@media (max-width: 620px){
  nav{display:none;}
  .menuBtn{display:inline-flex; align-items:center; justify-content:center;
    width:40px; height:40px; border-radius:14px;
    border:1px solid rgba(255,255,255,.14);
    background:rgba(255,255,255,.04);
    color:rgba(255,255,255,.86);
    cursor:pointer;
  }
  .menuDrawer{
    display:none;
    position:fixed;
    left:14px; right:14px; top:64px;
    border:1px solid rgba(255,255,255,.14);
    border-radius:20px;
    background:rgba(8,10,18,.92);
    box-shadow: 0 24px 80px rgba(0,0,0,.55);
    padding:10px;
    z-index:60;
  }
  .menuDrawer.open{display:block;}
  .menuDrawer a{display:flex; padding:12px 12px; border-radius:14px; text-decoration:none;
    color:rgba(255,255,255,.90);
  }
  .menuDrawer a:hover{background:rgba(255,255,255,.06);}
}

/* Hero CTAs: smaller + not dominating on mobile */
@media (max-width: 620px){
  .hero{padding-top:26px;}
  .ctaRow{gap:10px;}
  .ctaRow .btn{padding:10px 12px; font-size:13px;}
  .ctaRow .btn.primary{padding:10px 12px;}
}

/* Scroller tiles: tighter on mobile */
@media (max-width: 620px){
  .hTile{min-width:160px; max-width:170px;}
}


/* Gameplay extras */
.tableWrap{overflow:auto; border-radius:18px; border:1px solid rgba(255,255,255,.10);}
.mxTable{width:100%; border-collapse:separate; border-spacing:0; min-width:680px; background:rgba(255,255,255,.02);}
.mxTable th,.mxTable td{padding:12px 12px; text-align:left; border-bottom:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.86); font-size:14px;}
.mxTable th{position:sticky; top:0; background:rgba(10,14,24,.92); backdrop-filter: blur(10px); font-size:12px; letter-spacing:1.4px; text-transform:uppercase; color:rgba(255,255,255,.70);}
.mxTable tr:last-child td{border-bottom:none;}
.badgeMini{display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04); color:rgba(255,255,255,.78); font-size:12px;}
.steps{display:grid; grid-template-columns:repeat(12,1fr); gap:16px; margin-top:12px;}
.stepCard{grid-column:span 6;}
.stepCard .num{font-size:22px; font-weight:800;}
@media (max-width:720px){.stepCard{grid-column:span 12;} .mxTable{min-width:540px;}}
.deckGrid{display:grid; grid-template-columns:repeat(12,1fr); gap:16px; margin-top:12px;}
.deck{grid-column:span 4;}
@media (max-width:920px){.deck{grid-column:span 6;}}
@media (max-width:720px){.deck{grid-column:span 12;}}
/* Print rules */
@media print{
  header, .ctaRow, 
  body{background:#fff !important; color:#000 !important;}
  .card{border:none !important; background:transparent !important; box-shadow:none !important;}
  .mxTable th,.mxTable td{color:#000 !important; border-color:#ddd !important;}
}

/* Flip on creature card pane */
.creatureHero .viewPane[data-view="card"] .flip{max-width:420px; margin:0 auto;}
.creatureHero .viewPane[data-view="card"] .flip:hover .flipInner{transform: rotateY(180deg);}


/* Desktop dropdown menu (hamburger) */
@media (max-width: 1200px){
  header nav{display:none;}
  .menuBtn{display:inline-flex;}
  .menuDrawer{top:64px;}
}
/* Robust card flip */
.flip{position:relative; perspective:1200px;}
.flipInner{position:relative; width:100%; height:100%; transform-style:preserve-3d; transition:transform .6s ease;}
.flipFace{position:absolute; inset:0; backface-visibility:hidden; -webkit-backface-visibility:hidden;}
.flipBack{transform:rotateY(180deg);}
/* Hover flip (desktop) */
.flip:hover .flipInner{transform:rotateY(180deg);}

.flipFace img{width:100%; height:100%; object-fit:contain; display:block;}


/* --- FIX: creature page card tab should always show flip card --- */
.page-creature .viewPane[data-view="card"]{ display:none; }
.page-creature .viewPane[data-view="card"].active{ display:block !important; }
.page-creature .viewPane[data-view="card"] .flip{
  display:block !important;
  width:100% !important;
  max-width:420px;
  margin:0 auto;
  aspect-ratio: 2 / 3 !important;
  min-height: 480px;
}
.page-creature .viewPane[data-view="card"] .flipInner{ position:absolute; inset:0; height:100% !important; }
.page-creature .viewPane[data-view="card"] .flipFace img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
}


/* === GLOBAL NAV DRAWER (mobile + desktop) === */
.menuBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.86);
  cursor:pointer;
  z-index:80;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.menuDrawer{
  display:none;
  position:fixed;
  right:14px;
  top:64px;
  left:auto;
  width:min(360px, calc(100vw - 28px));
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  background:rgba(8,10,18,.92);
  box-shadow: 0 24px 80px rgba(0,0,0,.55);
  padding:10px;
  z-index:90;
}
.menuDrawer.open{display:block;}
.menuDrawer a{
  display:flex;
  padding:12px 12px;
  border-radius:14px;
  text-decoration:none;
  color:rgba(255,255,255,.90);
}
.menuDrawer a:hover{background:rgba(255,255,255,.06);}

/* Use the drawer on small screens; keep regular nav on desktop but still show hamburger */
@media (max-width: 620px){
  nav{display:none;}
  .menuDrawer{left:14px; right:14px; width:auto;}
}
@media (min-width: 621px){
  header nav{display:flex;}
  /* keep hamburger visible on desktop too */
}






/* --- Header layout: keep hamburger at far right (desktop + mobile) --- */
header .headerInner{position:relative;}
header .brand{order:0;}
header nav{order:1;}
header .navCta{order:2;}
header .menuBtn{order:3; margin-left:auto;}
header .menuDrawer{order:4;}

/* --- Reduce hero/header vertical footprint --- */
.headerInner{padding:8px 12px;}
.hero{padding-top:14px; padding-bottom:18px;}
.hero h1{font-size:clamp(24px, 3.8vw, 46px); line-height:1.06;}
.hero .kicker{margin-bottom:6px;}
.hero .ctaRow{margin-top:12px;}


/* Emphasize rarity pill */
.pill.pillRarity{border-color: rgba(80,180,255,.9) !important; box-shadow: 0 0 0 1px rgba(80,180,255,.35) inset; font-weight:700; background: rgba(20,40,70,.45) !important;}
